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