博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
greendao 查询之数据去重
阅读量:6254 次
发布时间:2019-06-22

本文共 3054 字,大约阅读时间需要 10 分钟。

最近使用greendao的过程中,有一个需求:将数据库的内容根据组别展示。意思就是需要将数据库中的所有组别取出来,然后根据组别加载数据。之前我的笨办法是获取所有的数据,然后对得到的数据手动去重(比较每个实体的组别值是否一致,不是就加到一个List集合中)。 

笨办法在数量比较小的数据库里面不会有什么影响,但是为了追求完美,我查询了数据库,得到需要”SELECT DISTINCT”字段才能查询,但是SQLite都不会的我,怎么会查询这个呢?这个时候离成功很近了,不过我还是偷懒了——直接去查询人家是怎么实现的?

private static final String SQL_DISTINCT_ENAME = "SELECT DISTINCT "+EmpDao.Properties.EName.columnName+" FROM "+EmpDao.TABLENAME;public static List
listEName(DaoSession session) { ArrayList
result = new ArrayList
(); Cursor c = session.getDatabase().rawQuery(SQL_DISTINCT_ENAME, null); try{ if (c.moveToFirst()) { do { result.add(c.getString(0)); } while (c.moveToNext()); } } finally { c.close(); } return result;}

通过这个方法直接就可以实现了,但是这个DaoSession对象不好找,是greendao自动生成的对象,然后在EmpDao里面增加getDaoSession()方法是无效的,一编译就将手动添加的方法删除了。我是在自己的GreenDaoHelper方法里面找到的,代码如下:

/** * GreenDao多个数据库的支持类 * Created by Administrator on 2017/4/4 0004. */public class GreenDaoHelper {    private HashMap
hash = new HashMap
(); public String pBaseDbPath = "/PuCha2.0/PestGeneralSurvey/PuChaSurvey.db"; private Context pContext; public GreenDaoHelper(Context pContex,String pBaseDbPath){ this.pContext = pContex; this.pBaseDbPath = pBaseDbPath; initDatabase(pBaseDbPath); } /** * 初始化greenDao,这个操作建议在Application初始化的时候添加; */ public DaoSession initDatabase(String pPath) { // 通过 DaoMaster 的内部类 DevOpenHelper,你可以得到一个便利的 SQLiteOpenHelper 对象。 // 可能你已经注意到了,你并不需要去编写「CREATE TABLE」这样的 SQL 语句,因为 greenDAO 已经帮你做了。 // 注意:默认的 DaoMaster.DevOpenHelper 会在数据库升级时,删除所有的表,意味着这将导致数据的丢失。 // 所以,在正式的项目中,你还应该做一层封装,来实现数据库的安全升级。 DaoMaster.DevOpenHelper mHelper = new DaoMaster.DevOpenHelper(pContext, FormUtil.getInnerSDCardPath()+pPath, null); SQLiteDatabase db = mHelper.getWritableDatabase(); // 注意:该数据库连接属于 DaoMaster,所以多个 Session 指的是相同的数据库连接。 DaoMaster mDaoMaster = new DaoMaster(db); DaoSession mDaoSession = mDaoMaster.newSession(); hash.put(pPath,mDaoSession); return mDaoSession; } public DaoSession getDaoSession(String pDbPath) throws FileNotFoundException { DaoSession mDaoSession = hash.get(pDbPath); if(!fileIsExists(FormUtil.getInnerSDCardPath()+pDbPath)){ throw new FileNotFoundException(); } if(mDaoSession == null){ return initDatabase(pDbPath); } return mDaoSession; } public DaoSession getBaseDaoSession(){ DaoSession mDaoSession = hash.get(pBaseDbPath); if(mDaoSession == null){ return initDatabase(pBaseDbPath); } return mDaoSession; } public boolean fileIsExists(String pPath){ try{ File f=new File(pPath); if(!f.exists()){ return false; } }catch (Exception e) { // TODO: handle exception return false; } return true; }}

转载地址:http://yunsa.baihongyu.com/

你可能感兴趣的文章
PhoneURLConnectGEt
查看>>
darknet源码学习
查看>>
dl,dt,dd的用法
查看>>
外面的世界很精彩,然而等待你的人却可能已不在
查看>>
成为一名阿里P7Java架构师需要的技术准备(转载)
查看>>
华为oj 挑7
查看>>
【吴恩达机器学习】学习笔记——1.5无监督学习
查看>>
使用pjax实现类似github无刷新更改页面url
查看>>
移动端头部meta
查看>>
回溯法
查看>>
iOS常用宏定义
查看>>
memcached(一)--前言
查看>>
【转】各种排序算法时间复杂度和空间复杂度表
查看>>
Redis客户端集群
查看>>
EF异常:WebForm、Console、Winform层不引入EF报错
查看>>
System系统类常用方法
查看>>
15:开发Rsync服务启动脚本案例
查看>>
uva 1592(NEERC 2009 STL)
查看>>
Xqk.Data数据框架使用说明之:使用Xqk.Data的一般步骤
查看>>
makefile
查看>>