为hibernate添加数据库方言函数

在sessionFactory中配置hibernate.dialect属性,以mysql为例,class设置为自定义的类,
<bean id="chartSessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="dataSource" ref="chartDataSource" />
<property name="mappingLocations">
<list>
<value>classpath*:com/landray/kmss/hrt/chart/model/*.hbm.xml</value>
<value>classpath:com/landray/kmss/component/dbop/model/CompDbcp.hbm.xml</value>
<value>classpath:com/landray/kmss/hrt/config/model/HrtConfigPersonalInfo.hbm.xml</value>
<value>classpath:com/landray/kmss/hrt/config/model/HrtConfigTrainServer.hbm.xml</value>
<value>classpath:com/landray/kmss/hrt/config/model/HrtConfigTrainMain.hbm.xml</value>
<value>classpath:com/landray/kmss/hrt/config/model/HrtConfigTechnology.hbm.xml</value>
<value>classpath:com/landray/kmss/hrt/config/model/HrtConfigPolitics.hbm.xml</value>
<value>classpath:com/landray/kmss/hrt/config/model/HrtConfigFunction.hbm.xml</value>
<value>classpath:com/landray/kmss/hrt/config/model/HrtConfigEducation.hbm.xml</value>
<value>classpath:com/landray/kmss/hrt/config/model/HrtConfigNation.hbm.xml</value>
<value>classpath:com/landray/kmss/sys/organization/model/SysOrgPost.hbm.xml</value>
<value>classpath:com/landray/kmss/sys/organization/model/SysOrgGroupCate.hbm.xml</value>
<value>classpath:com/landray/kmss/sys/organization/model/SysOrgGroup.hbm.xml</value>
<value>classpath:com/landray/kmss/sys/organization/model/SysOrgElement.hbm.xml</value>
<value>classpath:com/landray/kmss/sys/organization/model/SysOrgPerson.hbm.xml</value>
<value>classpath:com/landray/kmss/hrt/course/scorm/model/HrtStudyCourse.hbm.xml</value>
<value>classpath:com/landray/kmss/hrt/course/scorm/model/HrtStudyCourseType.hbm.xml</value>
<value>classpath:com/landray/kmss/hrt/course/scorm/model/HrtCourseProperties.hbm.xml</value>
<value>classpath:com/landray/kmss/hrt/course/scorm/model/HrtStudyStudentCourse.hbm.xml</value>
</list>
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">com.landray.kmss.util.MySQLLocalDialect</prop>
<prop key="hibernate.show_sql">${chartDB.hibernate.show_sql}</prop>
<prop key="hibernate.format_sql">${chartDB.hibernate.format_sql}</prop>
<prop key="hibernate.jdbc.fetch_size">${chartDB.hibernate.jdbc.fetch_size}</prop>
<prop key="hibernate.jdbc.batch_size">${chartDB.hibernate.jdbc.batch_size}</prop>
<prop key="hibernate.cache.provider_class">org.hibernate.cache.HashtableCacheProvider</prop>
</props>
</property>
<property name="lobHandler" ref="defaultLobHandler2"></property>
</bean>


package com.landray.kmss.util;


import org.hibernate.dialect.function.SQLFunctionTemplate;

/**
* @author Zhangyanan
* 使mysql支持汉字排序
*/
public class MySQLLocalDialect extends org.hibernate.dialect.MySQL5Dialect {

public MySQLLocalDialect(){
super();
registerFunction("convert", new SQLFunctionTemplate(org.hibernate.Hibernate.STRING, "convert(?1 using ?2)") );
registerFunction("convert_gbk", new SQLFunctionTemplate(org.hibernate.Hibernate.STRING, "convert(?1 using gbk)") );
}

}

在hql中就可以使用 select u from User order by convert(personName,gbk)或者 select u from User order by convert_gbk(userName) 来实现按汉字拼音顺序排序了
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值