• 简单实用的Android ORM框架TigerDB


    TigerDB是一个简单的Android ORM框架,它能让你一句话实现数据库的增删改查,同时支持实体对象的持久化和自动映射,同时你也不必关心表结构的变化,因为它会自动检测新增字段来更新你的表结构。

    该库主要包括如下几个要点:

    1. 根据实体对象自动建表、新增字段(SQLite不支持删除字段列)
    2. 支持注解配置表名、字段名、字段默认值、主键是否自增长以及哪些字段不作为数据表中的映射字段
    3. 直接映射实体对象到SQLite数据库,实现一行代码对SQLite数据库增删改查
    4. 支持在SDCard中新建数据库db
    5. 解决在onCreate,onUpgrade中执行数据库其他操作时出现的异常(java.lang.IllegalStateException: getDatabase called recursively)
    6. 支持原生SQL语句操作数据库

    该ORM库使用过程中的主要类说明:

    1. SQLiteDBConfig:主要用于设置数据库的名字、创建路径、版本号、数据创建更新时的监听
    2. SQLiteDB:创建完数据库之后,主要通过此类来操作数据库的增删改查
    3. SQLiteDBFactory:该类主要用于创建SQLite数据库,同时缓存当前创建的SQLiteDB对象
    4. CursorUtil:查询数据库时,检测游标对象Cursor是否正常,解析Cursor数据为实体对象
    5. IDBListener:数据库创建、升级时的监听类,提供了空实现SimpleDBListener
    6. Column:该注解用来设置字段名、字段默认值
    7. PrimaryKey:该注解用来设置主键、主键字段名、以及主键是否为自增长
    8. Table:该注解用来设置表名,不设置的话默认类名为表名
    9. NotDBColumn:该注解用来设置哪些实体属性不映射到数据表中

    主要用法如下:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    //新建实体,可以通过注解@Table设置表名,如果不设置默认以类名User作为表名
    public class User {
    //设置主键id为自增长,也可以通过注解@Column设置字段名或字段默认值
    @PrimaryKey(isAutoGenerate=true)
    private long id;
     
    private String name;
     
    //设置age字段默认值为1
    @Column(defaultValue="1")
    private int age;
     
    //该字段不作为数据表中的字段
    @NotDBColumn
    private String bz;
     
    //必须实现无参构造
    public User() {
    }
     
    public User(String name) {
    super();
    this.name = name;
    }
    public long getId() {
    return id;
    }
    public void setId(long id) {
    this.id = id;
    }
    public String getName() {
    return name;
    }
    public void setName(String name) {
    this.name = name;
    }
     
    @Override
    public String toString() {
    return "{id=" + id + ",name=" + name + "}";
    }
    }
     
    //SQLite相关配置,包括数据库名字、创建路径、版本号、数据创建和升级时的监听
    SQLiteDBConfig config = new SQLiteDBConfig(this);
    //设置数据库创建更新时的监听,有提供空实现:SimpleDBListener
    config.setDbListener(new IDBListener() {
    @Override
    public void onUpgradeHandler(SQLiteDatabase db, int oldVersion, int newVersion) {
     
    }
     
    @Override
    public void onDbCreateHandler(SQLiteDatabase db) {
    showLongToast("数据库创建成功");
    }
    });
    //创建db,在创建数据库的时候,不需要在onDbCreateHandler手动去创建相关的数据表,在对实体对象进行数据操作的时候,会自动判断表是否存在,不存在的话会自动创建,同时如果有新增的字段也会自动更新表结构
    SQLiteDB db = SQLiteDBFactory.createSQLiteDB(config);
     
    //保存单个实体对象
    User user = new User("添加单个对象");
    int rtn = db.save(user)
     
    //保存集合对象
    List list = new ArrayList();
    int rtn = db.save(list)
     
    //查询User表中的所有数据
    List list = db.queryAll(User.class);
     
    //根据实体id(主键)查询User
    User user = db.query(User.class, "1");
     
    //查询User表中的数据总数
    long total = db.queryTotal(User.class);
     
    //删除指定实体对象
    db.delete(user);
     
    //更新实体对象
    db.update(user);
     
    //分页查询
    db.queryPage(claxx, curPage, pageSize);
     
    //根据SQL查询
    Cursor cursor = db.query(sql, bindArgs);

    源码及Demo地址:https://github.com/huyongli/TigerDB,大家可以自行下载查看

  • 相关阅读:
    分割回文串(力扣第131题)
    子集 II(力扣第91题)
    子集(力扣第78题)
    组合总和 III(力扣第216题)
    JavaWeb部分 (前序)
    JavaSE部分 (IO流下)
    JavaSE部分 (IO流上)
    JavaSE部分 (File类)
    Leetcode 08.04 幂集 回溯与位图
    Leetcode 1405 最长快乐字符串 穷举与贪心
  • 原文地址:https://www.cnblogs.com/android-blogs/p/5995827.html
Copyright © 2020-2023  润新知