android汉字排序,android sql汉字排序问题

1、汉字排序问题

android中一般排序按照时间的升降,但有时候需求要求按照字符串排序,刚开始想获取首字母排序,感觉比较麻烦,后来找到android的sqlite中有这样的原生功能

android中默认汉字(字符串)排序规则按照unicode排序

因此如果字段是汉语的话要用以下方式进行排序

orber by 字段 COLLATE LOCALIZED ASC

collate用于字符串表达式排序规则转换

以下是sql中的语法

COLLATE < collation_name >

< collation_name > ::=

{ Windows_collation_name } | { SQL_collation_name }

参数

collation_name

是应用于表达式、列定义或数据库定义的排序规则的名称。collation_name 可以只是指定的 Windows_collation_name 或 SQL_collation_name。

Windows_collation_name

是 Windows 排序规则的排序规则名称。请参见 Windows 排序规则名称。

SQL_collation_name

是 SQL 排序规则的排序规则名称。请参见 SQL 排序规则名称。

COLLATE 子句只能应用于 char、varchar、text、nchar、nvarchar 和 ntext 数据类型。

2、多条件排序问题

多条件排序以逗号分割

select * from time order by createtime desc,exetime asc;

3、多条件查询问题

有时候我们需要多条件查询,但条件的个数不确定,可以用下面的方式拼接sql语句

String selection = "1 = 1";

//第一个条件

if (area.length()>0) {

selection += " and " + DevicePlan.DevicePlanMetaData.COLUMN_NAME_ASSISTSNAME + " like " + "'%" + area + "%'";

}

//第二个条件

if (project.length()>0 ) {

selection += " and " + DevicePlan.DevicePlanMetaData.COLUMN_NAME_SYSTEMNAME + " like " + "'%" + project + "%'";

}

//第三个条件

if (name.length()>0) {

selection += " and " + DevicePlan.DevicePlanMetaData.COLUMN_NAME_PLANNAME + " like " + "'%" + name + "%'";

}

//第四个条件

if (number.length()>0) {

selection += " and " + DevicePlan.DevicePlanMetaData.COLUMN_NAME_PLANNUM + " like " + "'%" + number + "%'";

}

Cursor c = getActivity().getContentResolver().query(DevicePlan.DevicePlanMetaData.CONTENT_URI,

null,//String[] projection

selection,//String selection

null,//String[] selectionArgs

DevicePlan.DevicePlanMetaData.DEFAULT_SORT_ORDER);//String sortOrder

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值