SQLite之SQL语句构建

1、数据库链接(打开数据库)->传统方式创建表

 let path = Bundle.main.path(forResource: "test", ofType:".db")
 print(path!)
 let db = try! Connection(path!)
 try! db.execute("create table t_teacher(name text, email text)")

2、构建创建表SQL

    let users = Table("users")
    let id = Expression<Int>("id")
    let name = Expression<String>("name")
    let email = Expression<String?>("email")
    let sql = users.create { (t) in
          t.column(id)
          t.column(name)
          t.column(email)
    }
    print(sql)

3、执行动态SQL(主键,唯一,不能够为空)

try! db.run(sql)

4、插入数据

    let insert = users.insert(id <- 2, name <- "NSError", email <- "nserror@qq.com")
    try! db.run(insert)

5、更新数据 + 删除数据

  • 更新所有行
  let update = users.update(email <- "dream@qq.com", name <- "andy")
  print(update.asSQL())
  try! db.run(update)
  • 条件更新
 let filter = users.filter(name == "andy")
 try! db.run(filter.update(email <- "dream@qq.com"))
  • 内容替换
  let filter1 = users.filter(id == 1)
  try! db.run(filter1.update(name <- name.replace("r", with: "i")))
  • 删除所有
try! db.run(users.delete())
  • 条件删除->where条件
let alice = users.filter(id == 1)
let delete = alice.delete()
print(delete.asSQL())
try! db.run(delete)

6、查询数据

  • 查询所有
let seq:AnySequence = try! db.prepare(users)
for user in seq {
   //user->Row->表示一行数据
   print("name: \(user[name]), email: \(user[email])")
}
  • 条件查询->子段查询->只查询某些字段
for user in try! db.prepare(users.select(name)) {
     print("name: \(user[name])")
 }
  • 条件查询->"*"查询(所有字段)->通配符
  //查询所有特殊方法"*"->特殊字符
  for user in try! db.prepare(users.select(*)) {
      print("name: \(user[name])")
  }

查询子句

  • 查询子句->filter->where条件
   let query = users.select(email).filter(name == "NSLog")
   print(query.asSQL())
   let rows = try! db.prepare(query)
   for user in rows {
       print("name: \(user[email])")
   }
  • 查询子句->排序"order"
  let query = users.select(email, name).order(name.desc)
  print(query.asSQL())
  let rows = try! db.prepare(query)
  for user in rows {
     print("name: \(user[email]), phone:\(user[name])")
  }
  • 查询子句->LIMIT->查询多条->指定查询数据行数
        let query = users.select(email).limit(50)
        print(query.asSQL())
        for user in try! db.prepare(query) {
            print("name: \(user[email])")
        }
  • 查询子句->LIMIT->查询多条->指定查询数据开始位置行数
        let query = users.select(email).limit(1, offset: 1)
        print(query.asSQL())
        for user in try! db.prepare(query) {
            print("name: \(user[email])")
        }
  • 查询子句->LIMIT->查询一条(根据表)->不能指定数量->只有一条
        //注意:表中的第一条数据
        if let user = try! db.pluck(users) {
            print("phone: \(user[name])")
        }
  • 查询子句->过滤数据->contains
        //注意:必需是属性值全称(作为选项)
        let filter2 = users.filter(["Andy"].contains(name))
        print(filter2.asSQL())
        for user in try! db.prepare(filter2) {
            print("name: \(user[name])")
        }
  • 查询子句->过滤数据->模糊查询->like
        //后缀:查询以".com"结尾的行数据
        //前缀:查询以"andy@"开头的行数据
        //中缀:查询以"@"中间条件的行数据
        //模糊查询:特殊表示符号"%"
        let filter3 = users.filter(name.like("%n%"))
        print(filter3.asSQL())
        for user in try! db.prepare(filter3) {
            print("name: \(user[name]), email: \(user[email])")
        }
  • 查询子句->过滤数据->多条件查询->重载运算符->"&&"
        //例如:sql语句->select * from t_user where name = "Dream" and phone = 3
        //数据库框架中表示:&&->and
        let filter4 = users.filter( id == "1" && name == "NSError")
        print(filter4.asSQL())
        for user in try! db.prepare(filter4) {
            print("email: \(user[email])")
        }
  • 查询子句->过滤数据->多条件查询->重载运算符->"||"
        //||->"或"满足其中之一即可->对应数据库->"or"
        let filter5 = users.filter(name == "love" || name == "NSLog")
        print(filter5.asSQL())
        for user in try! db.prepare(filter5) {
            print("email: \(user[email])")
        }
  • 查询子句->过滤数据->多条件查询->重载运算符->">="
        let filter6 = users.filter(id >= "3")
        print(filter6.asSQL())
        for user in try! db.prepare(filter6) {
            print("email: \(user[email])")
        }
  • 查询子句->过滤数据->多条件查询->重载运算符->"<="
        let filter7 = users.filter(id <= "2")
        print(filter7.asSQL())
        for user in try! db.prepare(filter7) {
            print("email: \(user[email])")
        }
  • 查询子句->过滤数据->多条件查询->重载运算符->">"
        let filter8 = users.filter(name > "2")
        print(filter8.asSQL())
        for user in try! db.prepare(filter8) {
            print("email: \(user[email])")
        }
  • 查询子句->过滤数据->多条件查询->重载运算符->"<"
        let filter9 = users.filter(name < "2")
        print(filter9.asSQL())
        for user in try! db.prepare(filter9) {
            print("email: \(user[email])")
        }
  • 查询子句->过滤数据->多条件查询->重载运算符->"!="
        let filter10 = users.filter(name != "2")
        print(filter10.asSQL())
        for user in try! db.prepare(filter10) {
            print("email: \(user[email])")
        }
  • 查询子句->过滤数据->大小写转换
        //  name.lowercaseString == "DREAM"->结果->hello
        //  uppercaseString->大小->小写
        let filter11 = users.filter(name.uppercaseString == "LOVE")
        print(filter11.asSQL())
        for user in try! db.prepare(filter11) {
            print("email: \(user[email])")
        }
  • 查询子句->过滤数据->Table->where条件
        let filter12 = users.where(name == "love")
        print(filter12.asSQL())
        for user in try! db.prepare(filter12) {
            print("email: \(user[email])")
        }
  • 查询子句->过滤数据->group分组
        let filter13 = users.group(name)
        print(filter13.asSQL())
        for user in try! db.prepare(filter13) {
            print("email: \(user[name])")
        }

查询函数->scalar

  • count->当前表有多少行数据
        //获取行数方法
        //scalar->执行查询函数
        let c = users.count
        print(c.asSQL())
        let count = try! db.scalar(c)
  • count->查询指定条件对应的数据行数
        let count = try! db.scalar(users.select(name.count))
        print(count)
  • max/min->最大值/最小值
        let max = try! db.scalar(users.select(name.max))
        print(max!)
        let min = try! db.scalar(users.select(name.min))
        print(min!)
  • avg/sum(动态类型)/total->平均值/总和/总和
        let average = try! db.scalar(users.select(id.average))
        print(average!)
  • distinct->有几个分类(不同个数)
        let count = try! db.scalar(users.select(name.distinct.count))
        print(count)

7、表管理 + 表约束条件 + 事务处理

  • 重命名表名->首先:给Table增加rename方法
        try! db.run(users.rename(Table("t_user")))
  • 添加表字段
      //1、第一步:新增添加字段方法
        let sex = Expression<String?>("sex")
        try! db.run(users.addColumn(sex))
        
        //表约束条件(国外开源项目->牛逼->借鉴了FMDB->演变过来的)
        let students = Table("students")
        //备注:查询增加
        let sid = Expression<Int>("sid")
        let sname = Expression<String>("sname")
        let semail = Expression<String>("semail")
        //1、添加主键
        //做一个模版->然后根据我的模版自己尝试去实现其他约束条件
        //什么是主键?->核心:唯一性,不能够存在相同的值->自动增长
        let ssql = students.create { (t) in
            t.column(sid, primaryKey: true)
            t.column(sname)
            t.column(semail)
        }
        try! db.run(ssql)
  • 事务处理
        try! db.transaction {
            let insert = users.insert(id <- 5, name <- "efly", email <- "efly@qq.com")
            try! db.run(insert)
            try! db.run(users.insert(email <- "fan@qq.com"))
            //测试一下
            //思路
            //第一步:设置一个属性不能够为空->null->例如:name属性
            //提示:之前讲解添加约束条件方法
            //第二步:插入数据->事务管理->报错了
        }
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,670评论 5 460
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,928评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,926评论 0 320
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,238评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,112评论 4 356
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,138评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,545评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,232评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,496评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,596评论 2 310
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,369评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,226评论 3 313
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,600评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,906评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,185评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,516评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,721评论 2 335

推荐阅读更多精彩内容