一个简单的安卓数据库sqlite orm: orz

SQLiteORZ是一个简单的SQLite对象关系映射库,适用于小型项目或学习使用。通过继承DBBaseModel并初始化数据库,可以方便地进行CRUD操作,无需手动处理每个字段。文章介绍了如何引入和使用SQLiteORZ,包括插入、更新、查询和删除数据的方法。

sqliteorz

a simple sqlite orm which names orz

这是一个简单的sqlite orm
如果你希望可以使用少量的代码操作安卓sqlite
并且是作为学习或者小项目开发(不建议上生产,郭神的LitePal还是有保障的)
那么它很适合你
你只需要将你的数据库model继承DBBaseModel,初始化数据库
就可以不再对每个字段从cursor赋值了
一起来看看吧

如何引入

// corp from [jitpack](https://jitpack.io)
// step 1. Add the JitPack repository to your repositories
repositories {
    mavenCentral()
    maven { url "https://jitpack.io" }
}

// Step 2. Add the dependency
dependencies {
    implementation 'com.github.lawnvi:sqliteorz:1.0.0'
}

如何使用(CRUD)

/**
 * @DemoModel 让你的数据库的模型继承DBBaseModel
 * 请注意,至少需要一个空的构造函数,用于反射获取表信息
 */
data class DemoModel(
    var name: String = "",
    var age: Int = 18,
    var gender: Boolean = true,
    var content: String = "",
): DBBaseModel() {
    // 自定义表名
    override fun getTableName(): String {
        return super.getTableName()
    }
}

/**
 * 配置数据库名称,位置,表
 * 在可以获取到context的地方初始化数据库
 * 比如MainActivity的onCreate()
 */

/**
 * 三个参数均有默认值
 * name=package name
 * dirPath=/sdcard/Android/package/files/database
 * version=1, 需要注意的是,当增加或者变更model字段后需要改变version,此时会重新创建数据库,数据丢失
 * 郭神的LitePal好像是可以保留数据更新的
 */
val driver = DBDriver(name = "db", version = 1, dirPath = "/sdcard")
// 注册模型到数据库
driver.registerModel(DemoModel::class.java)
// 初始化数据库,为啥是array,因为支持多个数据库,厉害吧
OrzHelper.initialize(this.applicationContext, drivers = arrayOf(driver))

/**
 * 以下是增改查删的操作
 * 只有以下操作
 */

// insert
val obj = DemoModel("张三", age = (System.currentTimeMillis()%100).toInt())
obj.save()

// update, 存在id时 where: "id = $id",set: map
obj.update(mapOf("name" to "李四"))
// 或者new一个对像来update
DemoModel("").update(mapOf("name" to "李四"), "id > 1")
// 或者使用DBOrz
DBOrz.update<DemoModel>(mapOf("name" to "李四"), "id > 1")

// select
val objList = DBOrz.findModels<DemoModel>("id > 0")

// delete
obj.delete()

// count
val count = DBOrz.count<DemoModel>("id > 0")

插个源码路标 demo里有一个简单但完整的例子

有图有真相

根据你的描述,错误信息表明`sqlite_orm`库在尝试序列化`std::vector<int>`时失败了。具体来说,`sqlite_orm::internal::statement_serializer<std::vector<int>>`未被定义或未正确实现。 以下是问题的分析和解决方案。 --- ### 问题分析 1. **错误原因**: - `sqlite_orm`库内部需要将查询条件(例如`IN`子句中的值列表)序列化为SQL字符串。 - 默认情况下,`sqlite_orm`可能未提供对`std::vector`类型的序列化支持,或者你使用的版本较旧,导致模板实例化失败。 2. **解决方向**: - 确保`sqlite_orm`库支持`std::vector`类型的序列化。 - 如果不支持,可以通过自定义序列化逻辑来扩展`sqlite_orm`的功能。 --- ### 解决方案 #### 1. 确保`sqlite_orm`版本 首先,检查你使用的`sqlite_orm`版本是否支持`std::vector`类型的序列化。如果版本较旧,建议升级到最新版本。 #### 2. 自定义序列化逻辑 如果`sqlite_orm`未提供对`std::vector`类型的内置支持,可以手动为其添加序列化特化实现。 以下是一个示例代码,展示如何为`std::vector`类型添加序列化支持: ```cpp #include "sqlite_orm/sqlite_orm.h" #include <vector> #include <string> namespace sqlite_orm { namespace internal { // 为 std::vector 类型添加序列化支持 template<typename T> struct serializer<std::vector<T>> { static void to_sqlite(std::ostream& os, const std::vector<T>& vec) { os << "("; for (size_t i = 0; i < vec.size(); ++i) { if (i != 0) { os << ", "; } serializer<T>::to_sqlite(os, vec[i]); // 调用元素类型的序列化器 } os << ")"; } }; } // namespace internal } // namespace sqlite_orm // 定义一个表结构 struct TextureMapTableInDB { int id; std::string name; // Primary key bool operator==(const TextureMapTableInDB& other) const { return id == other.id && name == other.name; } }; int main() { auto storage = sqlite_orm::make_storage( ":memory:", sqlite_orm::make_table( "texture_map", sqlite_orm::make_column("id", &TextureMapTableInDB::id), sqlite_orm::make_column("name", &TextureMapTableInDB::name) ) ); // 插入一些数据 storage.sync_schema(); storage.insert(TextureMapTableInDB{1, "Texture1"}); storage.insert(TextureMapTableInDB{2, "Texture2"}); storage.insert(TextureMapTableInDB{3, "Texture3"}); // 使用 in 函数查询 std::vector<int> ids = {1, 3}; auto rows = storage.get_all<TextureMapTableInDB>( sqlite_orm::where(sqlite_orm::c(&TextureMapTableInDB::id).in(ids)) ); // 打印结果 for (const auto& row : rows) { std::cout << "ID: " << row.id << ", Name: " << row.name << std::endl; } return 0; } ``` --- ### 代码解释 1. **自定义序列化逻辑**: - 在`sqlite_orm::internal::serializer`命名空间中,为`std::vector`类型添加了一个特化实现。 - `to_sqlite`函数将`std::vector`转换为SQL中的`(value1, value2, ...)`格式。 2. **ORM表定义**: - 定义了一个名为`TextureMapTableInDB`的结构体,并将其映射到SQLite表。 - 使用`make_table`和`make_column`函数指定表名和列名。 3. **插入数据**: - 使用`storage.insert`插入几条记录。 4. **查询数据**: - 使用`sqlite_orm::c(&TextureMapTableInDB::id).in(ids)`生成SQL中的`IN`条件。 - 调用`storage.get_all`执行查询。 --- ###
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值