Sqlite中如何返回唯一数据

转载 2015年07月09日 00:41:27
SQLiteDatabase的Query方法都固定好参数了,distinct好像加不进去。
如果用execSQL方法在Select后面带上distinct,返回结果为void,得不到Cursor。

请问在Sqlite中怎样才能去掉重复得到唯一数据。


方案:

SQLiteDatabase类另有一个rawQuery方法,可以用自定义的SQL语句进行查询,返回Cursor类型。用这个方法可以进行稍微复杂一点的查询了。


SQLiteDatabase的rawQuery()用于执行select语句,使用例子如下:

<a target=_blank href="http://www.iteedu.com/handset/android/sqlitediary/SQLiteDatabase.php" style="color: rgb(51, 102, 153); text-decoration: none;">SQLiteDatabase</a> db= ....;
<a target=_blank href="http://www.iteedu.com/handset/android/sqlitediary/Cursor.php" style="color: rgb(51, 102, 153); text-decoration: none;">Cursor</a> cursor = db.rawQuery("select * from person",null);
...
cursor.close();
db.close();
rawQuery()方法的第一个参数为select语句;第二个参数为select语句中占位符参数的值,如果select语句没有使用占位符,该参数可以设置为null。带占位符参数的select语句使用例子如下:

<a target=_blank href="http://www.iteedu.com/handset/android/sqlitediary/Cursor.php" style="color: rgb(51, 102, 153); text-decoration: none;">Cursor</a> cursor = db.rawQuery("select * from personwhere name like ?and age=?", new String[]{"%iteedu%", "4"});


对于Android平台上的数据库而言使用了嵌入式越来越流行的SQLite,为了更好的跨平台我们推荐大家使用原始SQL语句直接操作,在代码和处理效率上都有不小的提高,不过要做好SQL语句异常处理。

下面我们说下rawQuery的好处,可以看到查询的代码直接使用SQL语句,通过性能实测效率比Android封装过的类要快不少,但不能配合一些 Adapter的使用,不过总体上在跨平台上很突出,下面为本地使用方法的伪代码,没有做任何构造和实例化,希望让项目经理知道rawSQL的优势在 Android平台上的使用。

  1. SQLiteDatabase db;
  2.   String args[] = {id};
  3.   ContentValues cv = new ContentValues();

  4.   cv.put("android123", id);
  5.   Cursor c = db.rawQuery("SELECT * FROM table WHERE android123=?", args); 执行本地SQL语句查询

  6.   if (c.getCount() != 0) {
  7.     //dosomething

  8.   ContentValues cv = new ContentValues();
  9.   
  10.   cv.put("android123","cwj");
  11.   db.insert("table", "android123", cv);  //插入数据

  12.   String args[] = {id};
  13.   ContentValues cv2= new ContentValues();
  14.   
  15.   cv2.put("android123", id);
  16.   db.delete("table", "android123=?", args); //删除数据

  17.   }

相关文章推荐

SQLite3 多字段联合唯一性,trigger使用分析

已经不是第一次用sqlite了,但是,每次都忘记要记录一下。每次都要重新找资料,所以,做完shi...

微信公众平台开发第一步(Java)——接口验证问题

问题描述:         租用虚拟主机空间,有公网IP,正确安装JDK与TOMCAT,         接口验证项目编写无误(经过多方测试),项目部署到服务器的TOMCAT后,浏览器访问正确...

开放平台-web实现QQ第三方登录

来源http://www.cnblogs.com/Leo_wl/p/4418790.html 应用场景     web应用通过QQ登录授权实现第三方登录。   操作步骤     1 ...

android sqlite新添唯一键constraint错误的解决方法

今天在做项目,需要在先前的表上面新增一个constraint,然后就用了“alter table mag_content_list add constraint unique(id);”这么一条语句。...
  • chant7
  • chant7
  • 2013年08月06日 16:39
  • 1431

MYSQL数据库(四) 数据插入、空值和非空判断、自动排序、主键约束、唯一约束

Mysql插入数据 插入数据:INSERT [INTO] tab_name[(col_name,…)] VALUES(val,…) 上一篇创建了一个数据库mm1,流程如下:首先我们创建了一个数据表...

python/pandas/Numpy数据分析-统计描述,唯一值,值计数

pandas 对象拥有一组常用的数学和统计方法,大部分属于简约统计,用于从Series中提取一个值,或者从DataFrame中提取一列或者一行Series注意:与NumPy数组相比,这些函数都是基于没...

数据结构 课设二: 唯一地确定一棵二叉树

唯一地确定一棵二叉树 【问题描述】 如果给出了遍历二叉树的前序序列和中序序列,则可以构造出唯 一的一棵二叉树。试编写实现上述功能的程序。 【基本要求】 ...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Sqlite中如何返回唯一数据
举报原因:
原因补充:

(最多只允许输入30个字)