ActiveSQLite 更简单的Swift数据库方案。项目地址:https://github.com/KevinZhouRafael/ActiveSQLite
——————————————————————————————————
在做swift数据库的时候,选择并不多,有三种:CoreData,SQLite,Realm。很多喜欢用SQL的开发者在Objective-c中使用FMDB,而在swift中,star最多的SQLite框架就是SQLite.swift,其star数量也才4k+,但是没有更好的选择了。SQLite.swift功能很强大,但是有几点非常不方便:
1,要写Expression表达式。
2,不能自动包装成对象。
参考如下代码:
let users = Table("users")
let id = Expression("id")
let email = Expression("email")
for stmt in try! db.prepare(users.select(id, email)) {
print("id: \(stmt[id]), email: \(stmt[email])")
}
1、在创建表,增删查改表都会用到Expression表达式,一般我们通常将表达式作为类的静态属性,这样统一管理。
2、读取stmt的数据只能显式的通过Expression表达式或者索引,这样在修改表的时候也是非常麻烦的,也很容易弄错。
为了让SQLite.swift更加好用,我写了一个框架ActiveSQLite,是对SQLite.swift的封装。主要特性:
1、自动创建表。
2、增删查改支持String和key-value的字典。
3、自动把查询结果包装为model。
4、更方便的事务和异步,模型与数据库表映射,日志,简便的数据库升级。
写的过程参考了MagicalRecord,ActiveRecord。易用性达到Realm的级别。
——————————————————————————————————————
具体介绍如下:
特性
- 支持 SQLite.swift 的所有特性。
- 自动创建表. 自动创建 id , created_at 和 updated_at 列。
- 自动把SQL查询的数据赋值给数据库模型DBModel的属性。
- 自定义表名和模型名之间的映射,列名和模型的属性名之间的映射。
- 支持事务和异步。
- 提供可扩展,链式,延迟执行的查询接口。
- 通过属性名字符串,字典,或SQLite.swift的表达式Expression查询和修改数据。
- 日志级别
例子
执行 ActiveSQLiteTests target.
用法
import ActiveSQLite
//定义model和table
class Product:DBModel{
var name:String!
var price:NSNumber!
var desc:String?
var publish_date:NSDate?
}
//保存
let product = Product()
product.name = "iPhone 7"
product.price = NSNumber(value:599)
try! product.save()
//查询
let p = Product.findFirst("name",value:"iPhone") as! Product
//or
let name = Expression<String>("name")
let p = Product.findAll(name == "iPhone")!.first as! Product
//id = 1, name = iPhone 7, price = 599, desc = nil, publish_date = nil, created_at = 1498616987587.237, updated_at = 1498616987587.237,
//更新
p.name = "iPad"
try! p.update()
//删除
p.delete()
开始
在你的工程的target使用ActiveSQLite, 需要首先导入 ActiveSQLite
模块.
import ActiveSQLite