Android开发中使用SQLite数据库进行数据存储是很常见的做法,而对于数据库中数据的排序也是很重要的操作。本篇文章将介绍在Android开发中如何对查询的数据库进行排序。
创新互联建站坚持“要么做到,要么别承诺”的工作理念,服务领域包括:网站制作、成都网站制作、企业官网、英文网站、手机端网站、网站推广等服务,满足客户于互联网时代的奉节网站设计、移动媒体设计的需求,帮助企业找到有效的互联网解决方案。努力成为您成熟可靠的网络建设合作伙伴!
一、查询数据库
首先需要先打开或创建一个数据库,然后进行查询。查询可以使用SQLiteDatabase类的query()方法来完成,该方法有很多重载,最常用的方法如下:
“`
public Cursor query (String table, String[] columns, String selection, String[] selectionArgs, String groupBy, String having, String orderBy, String limit)
“`
– table:指定要查询的表名
– columns:需要查询的字段
– selection:WHERE子句,指定查询的条件
– selectionArgs:WHERE子句中有占位符时使用,占位符将会被selectionArgs中的参数替换
– groupBy:指定分组的列
– having:指定分组的条件
– orderBy:指定排序的列
– limit:指定查询结果的数量限制
二、按照列名排序
要按照列名进行排序,只需要在查询时指定orderBy参数即可。例如,按照score列从低到高排序,代码如下:
“`
SQLiteDatabase db = dbHelper.getReadableDatabase();
Cursor cursor = db.query(“student”, null, null, null, null, null, “score asc”, null);
“`
以上代码中,orderBy参数指定为”score asc”,表示按照score列升序排序。
同理,可以使用”desc”关键字来指定倒序排序。例如,按照score列从高到低排序,代码如下:
“`
Cursor cursor = db.query(“student”, null, null, null, null, null, “score desc”, null);
“`
三、按照多个列名排序
当需要按照多个列名进行排序时,只需要在orderBy参数中指定多个列名即可,多个列名之间用逗号分隔。例如,先按照score列进行排序,如果score列相同,则按照id列进行排序,代码如下:
“`
Cursor cursor = db.query(“student”, null, null, null, null, null, “score asc, id asc”, null);
“`
以上代码中,orderBy参数指定为”score asc, id asc”,表示按照score列升序排序,如果score列值相同,则按照id列升序排序。
四、按照自定义规则排序
当需要按照自定义规则进行排序时,可以使用SQL语句中的CASE语句实现。例如,在score列值为60的记录之前添加一条记录,代码如下:
“`
Cursor cursor = db.rawQuery(“select *, ” +
“case when score=60 then 0 ” +
“else 1 end as sort ” +
“from student ” +
“order by sort asc, score asc”, null);
“`
以上代码中,使用rawQuery()方法执行原生的SQL语句,使用CASE语句实现自定义排序。当score列值为60时,将排序规则设为0,其他情况设为1,然后按照sort、score列升序排序。
五、
本篇文章介绍了在Android开发中如何对查询的数据库进行排序。简单来说,只需要在查询时指定orderBy参数即可实现排序。可以按照列名排序,也可以按照多个列名排序。当需要按照自定义规则排序时,可以使用SQL语句中的CASE语句实现。在实际开发中,需要根据不同的业务需求选择不同的排序方式。
成都网站建设公司-创新互联,建站经验丰富以策略为先导10多年以来专注数字化网站建设,提供企业网站建设,高端网站设计,响应式网站制作,设计师量身打造品牌风格,热线:028-86922220三种,个别手机更多
数组排序 冒泡排序
最顷世好使用Android自带的排序方法
实现接口Comparator
使用拦族Arrays.sort()排雀衡肢序数组
不
HashMap排序是数据结构与亮拿算法中常见的一种排序算法。本文即以Android平台为例来实现该算法。
具体代码如下: public static void main(String args) { Map map = new HashMap(); map.put(“lisi”, 5); map.put(“lisi1”, 1); map.put(“lisi2”, 3); map.put(“lisi3”, 9); List> infoIds = new ArrayList>( map.entrySet()); System.out.println(“排序前”); for (int i = 0; i >() { public int compare(Map.Entry o1, Map.Entry o2) { return ( o1.getValue()-o2.getValue()); } }); System.out.println(“排序后”); for (int i = 0; i ent=infoIds.get(i); System.out.println(ent.getKey()+”蔽罩=”+ent.getValue()); }}
你说掘晌拍的按要求排序,应该谨滚是有一些自定义规则排序吧,假如要通过判羡值来排序可以用以下方法: Java代码 public static void main(String args) { Map map = new HashMap(); map.put(“lisi”, 5); map.put(“lisi1”, 1); map.put(“lisi2”, 3);
java中的Map是个key-valus形式存储的健值对接口。Map是个接口,因此不能实例化,不同的子类有不同的实现方式。
HashMap 无序的,通过hash算法来(散列存储)。
Hashtable 无序的,通过hash算法来(散列存储),与HashMap不睁弯同的是Hashtable 是同步的(线程安全的)。
LinkedHashMap 有序的,通过缺早羡双向链表来伏拍存储数据。
TreeMap 排序的,通过Key来排序,排序规则会调用key的compareTo方法来计算。
关于android 查询数据库排序的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。
成都创新互联科技有限公司,经过多年的不懈努力,公司现已经成为一家专业从事IT产品开发和营销公司。广泛应用于计算机网络、设计、SEO优化、关键词排名等多种行业!
新闻名称:Android如何对查询的数据库进行排序(android查询数据库排序)
文章链接:http://www.stwzsj.com/qtweb/news47/797.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联