LitePal

关于LitePal(github地址)

三步曲:
1. 添加依赖:api 'org.litepal.android:java:3.0.0'
2. 在assets中生成litepal.xml文件;具体内容查看litepal.xml
3. application继承LitePalApplication  或者添加:LitePal.initialize(this);
<?xml version="1.0" encoding="utf-8"?>
<litepal>
    <!--设定数据库的名字-->
    <dbname value="curry"></dbname>

    <!--设定数据库的版本号[需要纯数字]-->
    <version value="2"></version>

    <!--用于设定所有的映射模型-->
    <list>
        <mapping class="com.curry.basic.test.TestBean"></mapping>
        <mapping class="com.curry.basic.test.AllBean"></mapping>
        <mapping class="com.curry.basic.test.ChildBean"></mapping>
        <mapping class="com.curry.basic.test.OnlyBean"></mapping>
    </list>
</litepal>
  • 数据库相关(表关联):
    • 一对一:数据表根据外键进行关联(哪个表添加外键都可以);两个实体类相互持有对方的引用;
    • 多对一:数据表根据外键进行关联(多方添加外键);通过集合类;
    • 多对多:添加中间表存放两表的id;通过集合的多持有;
  • 对象关系映射的数据类型: int、short、long、float、double、boolean、String和Date
  • 建表:
    • 新建实体类,即数据库表;
    • 根据对象关系映射,以上的数据类型都会映射到数据库表中;
    • 然后在litepal.xml中配置模型类的类名
    • 执行SQLiteDatabase db = Connector.getDatabase();操作数据后,即可生成;
  • 升级表: 仅需要添加需要新增的模型类,然后在xml中配置即可【版本号要加1】
  • 增、删、改、差: 都可以通过LitePal进行操作;或者对实体类进行操作,注意删除功能要对已经持久化过的实体类进行删除才起作用;可以通过isSaved判断实体类是否持久化。
  • 聚合函数:
    • litepal.count(testbean.class);//统计行数
    • litepal.sum(testbean.class, "test", int.class);//求和
    • litepal.average(testbean.class, "test");//求平均值
    • litepal.max(testbean.class, "test", int.class);//求最大
    • litepal.min(testbean.class, "test", int.class);//求最小

其他:

SQLite不支持删除列的命令吗?那LitePal又是怎样做到的呢?
其实LitePal并没有删除任何一列,它只是先将comment表重命名成一个临时表,
然后根据最新的Comment类的结构生成一个新的comment表,
再把临时表中除了publishdate之外的数据复制到新的表中,最后把临时表删掉。
因此,看上去的效果好像是做到了删除列的功能。

PS:

在module中也可正常使用,xml放在module中的assets文件中,主工程是可以正常调用的。(亲试有效哦)

参考/感谢:郭霖Android数据库高手秘籍

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容