基于SQLite和Annotation的android数据库ModelSQLite

        原本使用数据库的时候,需要根据存储字段建立对应表和列,以及对应增删改查逻辑。于是便想要找到一种方法,只创建一次数据库表格,并且今后的增删改查都用一套逻辑完成。后来想到了将列与数据字段的对应关系放在数据模型之中,这样每一列只关心保存的数据类就可以了。

        首先需要了解一下三个关键注解:

        1.@SQLiteClassify:用于数据模型类的注解,相当于表名;

        2.@SQLiteColumn:用于数据模型内部字段的注解,相当于列名,支持int、boolean、long、double、float、short、String几种类型,其中boolean值会以“0”和“1”的形式保存,其余类型会转为String(json)数据保存;使用时候需要选择合适的列名,保证字段类型与保存类型一致;

        3. @SQLiteRelevance:用于表与表之间的关联,被绑定的字段需要拥有@SQLiteClassify注解(即自定义的数据模型类),并选取一个被绑定字段内部字段作为查询的关键字,将此关键字保存在当前表格中。

        对于表格中列的创建,是采用遍历ColumnEnum枚举类内部字段,根据字段的值创建对应类型的列,目前暂不支持动态增加列,只能通过修改ColumnEnum文件实现。

        在使用方面,首先需要初始化CacheDao的CacheInitInterface接口:

图1

        CacheUtil内实现了CacheDao的单例,每个CacheDao对应一个userCache.db文件,每一个db文件内只有一张表(userCache),通过CacheUtil获取CacheDao进行据操作。如果需要建立多张表格,需要在不同文件夹下初始化CacheDao。

        所有的条件语句,全部依赖SQLiteInfo类完成,CacheDao会在具体执行的时候自动将SQLiteInfo内的数据转化为对应sqlite语句并完成对应的执行操作。目前SQLiteInfo对外暴露的方法有4个:

        1.addOrderInfo(ColumnEnum columnName):添加排序条件;

        2.setAsc(boolean asc):设置升序降序;

        3.addQueryCondition(ColumnInfo info):添加关系条件(有多种实现,最后全部是执行这个方法);目前支持的关系见下图2。ColumnInfo 内有三个字段:ColumnEnum columnName(列名)、String relation(关系,默认为“=?”)、Object columnValue(对应值)

图2

        4.setOtherCondition(String otherCondition):预留的方法,添加其他条件语句,执行的时候会直接加到sqlite语句后面。

        主要使用方法(CacheDao):

        1.保存:saveValue,可不带查询条件。若返回-1代表失败;返回0代表新增;返回1代表更新。saveByArray,多条保存,无返回值,内部实际上是多次调用了saveValue;

        2.查询:selectValueModel,可不带查询条件,receiver为数据接收者,查询到数据已通过反射保存到receiver中的对应字段,若查到的数据与receiver不匹配则receiver不会变化。例如:CacheUtil.instance().selectValueModel(new Group(), sqLiteInfo)。getColumnValue,查询指定的列。 selectValueList多条查询,有多种实现,差别在于如何新建数据的receiver以及查询的条目数量、范围。getSelectCursor获取查询结果光标。

        3.删除:delete以及deleteByArray,单条删除和多条删除。

        4.更新:updateColumn更新某一列上的值。

几个简单的例子:

初始化
多条查询
单条保存

单条删除

demo地址:https://github.com/FirstLetterZ/MySQLiteDemo.git

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,684评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,143评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,214评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,788评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,796评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,665评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,027评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,679评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,346评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,664评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,766评论 1 331
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,412评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,015评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,974评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,073评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,501评论 2 343

推荐阅读更多精彩内容

  • 1. 简介 1.1 什么是 MyBatis ? MyBatis 是支持定制化 SQL、存储过程以及高级映射的优秀的...
    笨鸟慢飞阅读 5,423评论 0 4
  • 转 # https://www.cnblogs.com/easypass/archive/2010/12/ 08/...
    吕品㗊阅读 9,696评论 0 44
  • 国家电网公司企业标准(Q/GDW)- 面向对象的用电信息数据交换协议 - 报批稿:20170802 前言: 排版 ...
    庭说阅读 10,863评论 6 13
  • 服务器重启后,mysqld无法启动,启动命令是:service mysqld start mysql的错误日志如下...
    CaiGuangyin阅读 1,487评论 0 0
  • 没事的时候,总是喜欢在我们乡村的集市上转转,看看有无可买之物。毕竟许久没有逛街了,见到熟悉的面孔还是会很亲切的唠上...
    zhuimengren阅读 258评论 2 6