hibernate 用hql做中文排序
用Hibernate+MySQL的童鞋是不是非常苦恼为什么MySQL不支持中文排序呢?没办法。仅仅有等utf8_unicode_cn 出来了。假设用hibernate即想实现跨库,又想不改代码怎样实现呢。下边告诉你答案。
方法一、描写叙述:给Hibernate的MySQL方言包注冊一个排序方法,该方法中实现了MySQL中文排序。
贴代码:
public class MySQLExtendDialect extends MySQLDialect { public MySQLExtendDialect(){ super(); registerFunction("convert_gbk", new SQLFunctionTemplate(Hibernate.STRING, "convert(?1 using gbk)") ); } }该方法的弊端是须要改不同数据的方言包来实现不改代码的跨库。(须要改order by field 为 order by convert_gbk(field))。
方法二、描写叙述:单独改动Hibernate的MySQL方言包,改动order by方法,使该方法默认使用convert方法来实现中文排序。贴代码:
public class MySQLGBKDialect extends MySQLDialect { public MySQLGBKDialect() { } public String renderOrderByElement(String expression, String collation, String order, NullPrecedence nulls) { expression = (new StringBuilder("convert(")).append(expression).append(" using 'gbk')").toString(); return super.renderOrderByElement(expression, collation, order, nulls); } }renderOrderByElement该方法为复写父类中的方法,长处是不用改其它数据方言包,不用改代码,缺点是全部的排序方法将都运行convert方法。