hibernate mysql 中文排序_SSH系列:(25)Hibernate中文排序

1、中文排序SQL语句(MySQL)select 列名 from 表名 order by convert(列名 using gb2312) asc;

2、中文排序Hibernate

2.1、自定义一个类,继承MySQL5Dialectpackage com.rk.core.utils;

import org.hibernate.dialect.MySQL5Dialect;

import org.hibernate.dialect.function.SQLFunctionTemplate;

import org.hibernate.type.StandardBasicTypes;

public class MySQLExtendDialect extends MySQL5Dialect {

public MySQLExtendDialect() {

super();

registerFunction("convert_gbk", new SQLFunctionTemplate(StandardBasicTypes.STRING , "convert(?1 using gbk)"));

}

}

这里虽然是MySQL5Dialect,也可以是其它类。

2.2、在applicationContext中使用自定义的类

修改sessionFactory的部分

org.hibernate.dialect.MySQL5Dialect

true

false

update

classpath:com/rk/*/entity/*.hbm.xml

改变之前:org.hibernate.dialect.MySQL5Dialect

改变之后:com.rk.core.utils.MySQLExtendDialect

2.3、排序

下面是RoleAction.java的一段代码//列表页面

public String listUI(){

//加载权限集合

ActionContext.getContext().getContextMap().put("privilegeMap", PrivilegeStatics.PRIVILEGE_MAP);

try {

QueryHelper queryHelper = new QueryHelper(Role.class, "r");

queryHelper.addCondition("r.state=?", Role.ROLE_STATE_VALID);

if(StringUtils.isNotBlank(searchContent)){

searchContent = URLDecoder.decode(searchContent, "utf-8");

queryHelper.addCondition("r.name like ?", "%"+searchContent+"%");

}

queryHelper.addOrderByProperty("convert_gbk(r.name)", QueryHelper.ORDER_BY_ASC);

String hql = queryHelper.getQueryListHql();

System.out.println(hql);

pageResult = roleService.getPageResult(queryHelper, pageNo, pageSize);

} catch (Exception e) {

e.printStackTrace();

}

return "listUI";

}

其中使用排序的地方是queryHelper.addOrderByProperty("convert_gbk(r.name)", QueryHelper.ORDER_BY_ASC);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值