mybatis 中文显示不正常的问题

xevvex 2016-07-14 03:09:21
大神们,我写了一段sql里面有一段是这样的:
case when t.status= 0 then "下单成功" when t.status= 1 then "购买成功,购买资格已审核通过" when t.status= "2" then "超时未付关闭" when t.status= 21 then "已删除" else t.status end status,
case when t.audit_flag= 0 then "待审核" when t.audit_flag= 1 then "审核通过" when t.audit_flag= 2 then "审核未通过" else t.audit_flag end auditFlag,
这个字段显示到页面的时候都变成了[B@48be170b类似这种好像是对象的显示了,应该不是编码的问题 ,数据库里面存的中文是正常显示的 只是case when设定的中文不正常,这个应该咋办呢 Google了半天都是解决中文乱码的问题,跟我这个情况不一样,求解答
...全文
315 8 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
lynnlovemin 2016-07-15
  • 打赏
  • 举报
回复
引用 7 楼 xevvex 的回复:
[quote=引用 5 楼 qq_33456238 的回复:] 试试这样写 case t.status when 0 then '下单成功' when 1 then '购买成功,购买资格已审核通过' when 2 then '*******' when 3 then '*************' end ) as status
已经试过 结果一样
引用 6 楼 lynnlovemin 的回复:
[quote=引用 2 楼 xevvex 的回复:] [quote=引用 1 楼 lynnlovemin 的回复:] [B@48be170b 打印的这个 很明显是个对象,你应该显示该对象下的属性
是的 ,我知道是对象,如果按照case when显示结果为中文的话,系统莫名其妙的自动把另外一列和这一列组合一起成为一个对象,但是如果我去掉case when 只是显示status的话就不会自动组合,从而正常显示了,所以就想知道这是为啥 是不是mybatis有什么使用上的限制[/quote] 跟mybatis关系不大吧 他直接操作的是sql,而且为什么要用case when呢 一般我们不建议用,效率比较低[/quote] 因为是一个临时的需求 就打算尽快出了就好 没想到反而除了莫名其妙的问题[/quote] 我大概知道你要实现什么功能,你sql不要写case when 就直接查询出status 然后在页面上判断,不就行了
xevvex 2016-07-15
  • 打赏
  • 举报
回复
引用 5 楼 qq_33456238 的回复:
试试这样写 case t.status when 0 then '下单成功' when 1 then '购买成功,购买资格已审核通过' when 2 then '*******' when 3 then '*************' end ) as status
已经试过 结果一样
引用 6 楼 lynnlovemin 的回复:
[quote=引用 2 楼 xevvex 的回复:] [quote=引用 1 楼 lynnlovemin 的回复:] [B@48be170b 打印的这个 很明显是个对象,你应该显示该对象下的属性
是的 ,我知道是对象,如果按照case when显示结果为中文的话,系统莫名其妙的自动把另外一列和这一列组合一起成为一个对象,但是如果我去掉case when 只是显示status的话就不会自动组合,从而正常显示了,所以就想知道这是为啥 是不是mybatis有什么使用上的限制[/quote] 跟mybatis关系不大吧 他直接操作的是sql,而且为什么要用case when呢 一般我们不建议用,效率比较低[/quote] 因为是一个临时的需求 就打算尽快出了就好 没想到反而除了莫名其妙的问题
lynnlovemin 2016-07-14
  • 打赏
  • 举报
回复
引用 2 楼 xevvex 的回复:
[quote=引用 1 楼 lynnlovemin 的回复:] [B@48be170b 打印的这个 很明显是个对象,你应该显示该对象下的属性
是的 ,我知道是对象,如果按照case when显示结果为中文的话,系统莫名其妙的自动把另外一列和这一列组合一起成为一个对象,但是如果我去掉case when 只是显示status的话就不会自动组合,从而正常显示了,所以就想知道这是为啥 是不是mybatis有什么使用上的限制[/quote] 跟mybatis关系不大吧 他直接操作的是sql,而且为什么要用case when呢 一般我们不建议用,效率比较低
曲奇丶 2016-07-14
  • 打赏
  • 举报
回复
试试这样写 case t.status when 0 then '下单成功' when 1 then '购买成功,购买资格已审核通过' when 2 then '*******' when 3 then '*************' end ) as status
  • 打赏
  • 举报
回复
Terence Jing 2016-07-14
  • 打赏
  • 举报
回复
都是高手
xevvex 2016-07-14
  • 打赏
  • 举报
回复
引用 1 楼 lynnlovemin 的回复:
[B@48be170b 打印的这个 很明显是个对象,你应该显示该对象下的属性


是的 ,我知道是对象,如果按照case when显示结果为中文的话,系统莫名其妙的自动把另外一列和这一列组合一起成为一个对象,但是如果我去掉case when 只是显示status的话就不会自动组合,从而正常显示了,所以就想知道这是为啥 是不是mybatis有什么使用上的限制
lynnlovemin 2016-07-14
  • 打赏
  • 举报
回复
[B@48be170b 打印的这个 很明显是个对象,你应该显示该对象下的属性
MyBatis 目录(?)[-] mybatis实战教程mybatis in action之一开发环境搭建 mybatis实战教程mybatis in action之二以接口的方式编程 mybatis实战教程mybatis in action之三实现数据的增删改查 mybatis实战教程mybatis in action之四实现关联数据的查询 mybatis实战教程mybatis in action之五与spring3集成附源码 mybatis实战教程mybatis in action之六与Spring MVC 的集成 mybatis实战教程mybatis in action之七实现mybatis分页源码下载 mybatis实战教程mybatis in action之八mybatis 动态sql语句 mybatis实战教程mybatis in action之九mybatis 代码生成工具的使用 mybatis SqlSessionDaoSupport的使用附代码下载 转自:http://www.yihaomen.com/article/java/302.htm (读者注:其实这个应该叫做很基础的入门一下下,如果你看过Hibernate了那这个就非常的简单) (再加一条,其实大家可以看官方的教程更好些:http://mybatis.github.io/mybatis-3/,而且如果英文不是很好的那就看中文的:http://mybatis.github.io/mybatis-3/zh/sqlmap-xml.html) 写在这个系列前面的话: 以前曾经用过ibatis,这是mybatis的前身,当时在做项目时,感觉很不错,比hibernate灵活。性能也比hibernate好。而且也比较轻量级,因为当时在项目中,没来的及做很很多笔记。后来项目结束了,我也没写总结文档。已经过去好久了。但最近突然又对这个ORM 工具感兴趣。因为接下来自己的项目中很有可能采用这个ORM工具。所以在此重新温习了一下 mybatis, 因此就有了这个系列的 mybatis 教程. 什么是mybatis MyBatis是支持普通SQL查询,存储过程和高级映射的优秀持久层框架。MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及结果集的检索。MyBatis使用简单的XML或注解用于配置和原始映射,将接口和Java的POJOs(Plan Old Java Objects,普通的Java对象)映射成数据库中的记录. orm工具的基本思想 无论是用过的hibernate,mybatis,你都可以法相他们有一个共同点: 1. 从配置文件(通常是XML配置文件中)得到 sessionfactory. 2. 由sessionfactory 产生 session 3. 在session 中完成对数据的增删改查和事务提交等. 4. 在用完之后关闭session 。 5. 在java 对象和 数据库之间有做mapping 的配置文件,也通常是xml 文件。 mybatis实战教程(mybatis in action)之一:开发环境搭建 mybatis 的开发环境搭建,选择: eclipse j2ee 版本,mysql 5.1 ,jdk 1.7,mybatis3.2.0.jar包。这些软件工具均可以到各自的官方网站上下载。 首先建立一个名字为 MyBaits 的 dynamic web project 1. 现阶段,你可以直接建立java 工程,但一般都是开发web项目,这个系列教程最后也是web的,所以一开始就建立web工程。 2. 将 mybatis-3.2.0-SNAPSHOT.jar,mysql-connector-java-5.1.22-bin.jar 拷贝到 web工程的lib目录. 3. 创建mysql 测试数据库和用户表,注意,这里采用的是 utf-8 编码 创建用户表,并插入一条测试数据 程序代码 程序代码 Create TABLE `user` ( `id` int(11) NOT NULL AUTO_INCREMENT, `userName` varchar(50) DEFAULT NULL, `userAge` int(11) DEFAULT NULL, `userAddress` varchar(200) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8; Insert INTO `user` VALUES ('1', 'summer', '100', 'shanghai,pudong'

81,122

社区成员

发帖
与我相关
我的任务
社区描述
Java Web 开发
社区管理员
  • Web 开发社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧