hibernate 支持中文排序

public class Oracle_Order extends Order implements Serializable {


/**
* 扩展order 支持oracle 按笔划,部首,拼音排序。
*/
private static final long serialVersionUID = 1L;
// SCHINESE_STROKE_M' SCHINESE_RADICAL_M'); 'NLS_SORT=SCHINESE_PINYIN_M
private static int pinyin = 0; // 'NLS_SORT=SCHINESE_STROKE_M'
private static int radical = 1; // SCHINESE_RADICAL_M
private static int stroke = 2; // SCHINESE_STROKE_M
private String propertyName;
private int ascending = 0;
private int nulls = 0; //如果排序字段为空的话,空排最前。否则最后 //nulls first nulls last


protected Oacle_Order(String propertyName, int ascending , int nulls) {
super(propertyName, false);
// TODO Auto-generated constructor stub
this.propertyName = propertyName;
this.ascending = ascending;
this.nulls = nulls;
}

/**
* 只对准排序字段只有一个的情况,多个未考虑。
*/
public String toSqlString(Criteria criteria, CriteriaQuery criteriaQuery)
throws HibernateException {
String[] columns = criteriaQuery.getColumnsUsingProjection(criteria, propertyName);
String fragment = new String();
// nlssort(name,'NLS_SORT=SCHINESE_PINYIN_M') nulls first
if(this.ascending == 0)
fragment =" nlssort("+ columns[0] +",'NLS_SORT=SCHINESE_PINYIN_M') nulls "+(this.nulls==0?"first":"last");
else if(this.ascending == 1)
fragment =" nlssort("+ columns[0] +",'NLS_SORT=SCHINESE_RADICAL_M') nulls "+(this.nulls==0?"first":"last");
else
fragment =" nlssort("+ columns[0] +",'NLS_SORT=SCHINESE_STROKE_M') nulls "+(this.nulls==0?"first":"last");
// for ( int i=0; i<columns.length; i++ ) {
// fragment.append( columns[0] ).append( ascending ? " asc" : " desc" );
// if ( i<columns.length-1 ) fragment.append(", ");
// }
return fragment.toString();
}


public static Oacle_Order pinyu(String propertyName,int nulls)
{
return new Oacle_Order(propertyName,Oacle_Order.pinyin,nulls);
}

public static Oacle_Order radical(String propertyName,int nulls)
{
return new Oacle_Order(propertyName,Oacle_Order.radical,nulls);
}

public static Oacle_Order stroke(String propertyName,int nulls)
{
return new Oacle_Order(propertyName,Oacle_Order.stroke,nulls);
}

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值