zoukankan      html  css  js  c++  java
  • 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方法。

  • 相关阅读:
    18、【opencv入门】形态学图像处理(一):开运算、闭运算、形态学梯度、顶帽、黑帽合辑
    17、【opencv入门】形态学图像处理(一):膨胀与腐蚀
    16、【opencv入门】创建Trackbar & 图像对比度、亮度值调整
    c++ 售货员的难题
    c++ 火柴棒等式
    c++ 素数圈
    c++ 分解数
    c++ 走迷宫
    c++ 二叉树遍历
    c++ n皇后问题
  • 原文地址:https://www.cnblogs.com/blfshiye/p/5175977.html
Copyright © 2011-2022 走看看