在sqlite中执行'in'查询操作,如何使用selectionargs匹配多个值
来源:互联网 发布:盛世蠃家炒软件手机版 编辑:程序博客网 时间:2024/05/22 10:26
在安卓开发中,经常使用到sqlite作为本地持久化存储的解决方案。在androidSDK中,已经为我们提供了各种各样的增、删、改、查的api,尽管我们可以自己写sql语句然后执行db.rawsql(sql,null)方法,但这种方法有一些风险,那就是拼接的关键字有可能是非法的,这样会造成很多意想不到并且很危险的后果。因此,建议使用sdk提供的api来做数据库操作,android已经为我们屏蔽了这一层风险。
在使用sqlite查询时,我们经常会使用“in”操作符来进行查询,如
select * from tablename where userid in('张三','李四','王五');上面这条语句可以正确执行,但是正如上文提到的,这种方法是不安全的。因此,我们应该使用database.rawquery()方法来执行。那么,问题来了:学挖掘机技,不是,应该怎么传递这个方法的参数呢?通常我们会在拼接sql的时候用?这个占位符来表示一个关键词,如果in后面的括号里有多个关键词,那么有几个关键词我们就应该传几个?进去。因此可以使用下面这个方法来拼接这个占位符:
String makePlaceholders(int len) { if (len < 1) { throw new RuntimeException("No placeholders"); } else { StringBuilder sb = new StringBuilder(len * 2 - 1); sb.append("?"); for (int i = 1; i < len; i++) { sb.append(",?"); } return sb.toString(); } }在使用时可以这样做:
String placeHolder = makePlaceholders(usernames.size()); String sql = "select distinct username from " + TABLENAME + " where username in (" + placeHolder + ")"; String args = ""; for(int i = 0;i<usernames.size();i++){ args += tagUID.get(i).toString() + ","; } if(args.Length>1)args = args.substring(0,args.Length-1); cursor = db.rawQuery(sql, args.split(","));
ok,搞定~
0 0
- 在sqlite中执行'in'查询操作,如何使用selectionargs匹配多个值
- 如何在关联过滤中使用模糊匹配查询
- 如何在mybatis SQL查询中使用IN
- android中SqLite query中用selectionArgs处理字符传值
- 如何在ado.net中使用sqlite
- 在Android中如何使用SQLite
- 如何在Java中使用SQLite数据库
- 在SQLite中如何使用事务
- 如何绕过“ora-14551 无法在查询中执行DML操作”
- Android 中数据库查询方法 query() 中的 selectionArgs 的用法
- Android 中数据库查询方法query()中的selectionArgs的用法
- Android 中数据库查询方法 query() 中的 selectionArgs 的用法
- Android 中数据库查询方法 query() 中的 selectionArgs 的用法
- Android 中数据库查询方法query()中的selectionArgs参数解析
- Android 中数据库查询方法 query() 中的 selectionArgs 的用法
- Android 中数据库查询方法query()中的selectionArgs的用法
- 如何在 BroadcastReceiver 中执行耗时操作?
- 在SQLite中使用索引优化查询速度
- cell自动换行
- org.apache.jasper.JasperException: Unable to compile class for JSP(可能情况)
- 0143895吴彬第一次c++作业
- 【LeetCode从零单刷】Single Number
- 程序员书籍推荐
- 在sqlite中执行'in'查询操作,如何使用selectionargs匹配多个值
- 俯瞰,点击鼠标右键360度旋转物体
- 如何在Root的手机上开启ViewServer,使得HierachyViewer能够连接
- W3School 教程整理
- Android开源项目分类汇总
- Python学习笔记(四) -- 简单的爬虫
- FlashBuilder的air sdk和FlashPlayer升级方法
- 各个版本的Xcode/IOS SDK官网下载
- 1-12