LitePal

作者: Zcurry | 来源:发表于2018-12-27 18:03 被阅读0次

    关于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数据库高手秘籍

    相关文章

      网友评论

          本文标题:LitePal

          本文链接:https://www.haomeiwen.com/subject/lyjdlqtx.html