用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方法。