加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

SQLite FAQ 摘录

发布时间:2020-12-12 20:42:59 所属栏目:百科 来源:网络整理
导读:为了写手机程序,被迫研究SQLite。用惯了大型数据库,回头来看小的是怎么看怎么不顺眼。不过,先了解下FAQ总是有必要的。 如何定义自增主键 定义为 INTEGER PRIMARY KEY 的列会被设为从1开始自增,哪怕在使用时插入NULL值也会被自动替换。 sqlite3_last_inse

为了写手机程序,被迫研究SQLite。用惯了大型数据库,回头来看小的是怎么看怎么不顺眼。不过,先了解下FAQ总是有必要的。

  1. 如何定义自增主键
    定义为 INTEGER PRIMARY KEY 的列会被设为从1开始自增,哪怕在使用时插入NULL值也会被自动替换。
    sqlite3_last_insert_rowid()函数可以返回最新插入的行的rowid(注意多线程场合)。
    注意,自增主键会重新使用被删除的行的主键。要避免这种情况,可以使用 INTEGER PRIMARY KEY AUTOINCREMENT 定义
  2. 支持类型
    动态类型,可以是 INTEGER,REAL,TEXT,BLOB,NULL
  3. 在 INTEGER 列中插入字符串??!
    由于(该死的)动态类型,这样做是合法的,但是SQLite会尝试进行转换,如果这个字符串可以转换为INTEGER,则以INTEGER形式存储。该特性被称为 Type Affinity
  4. 同一个数据库文件可以被不同的程序同时访问吗?
    可以同时读取,但只有一个可以写入。
    在NFS文件系统上可能发生异常。
  5. 是否线程安全?
    理论上是。可以用 sqlite3_threadsafe() 函数进行判断。
    避免线程!
  6. 列举所有的表/索引
    命令行: .tables 列举所有表;.schema 列举所有表和索引
    SQL: SELECT name FROM sqlite_master WHERE type IN ('table','index')
  7. 容量限制
    string/BLOB: 1,000,000
    最大列数量:2000 (谁要真的用到成千上百的列,直接跳楼算了)
    SQL语句最大长度:1,000 (如需插入超过此长度的列数据,需要使用Parameters)
    最多可以Join的表:64
    最多可附加的数据库:10 (把多个数据库附加到同一个数据库连接)
    最大行数:1.8E19
  8. 如何向现有的表添加列
    ALTER TABLE仅支持重命名表或在表的末尾添加列。复杂操作必须通过临时表进行置换。
  9. ROUND(9.95,1)为什么不等于10
    对于浮点数来说无法精确表示9.95,SQLite认为其值为9.9499999……。
  10. 大小写敏感
    仅对ASCII字符有效,对Unicode字符都是敏感的。
  11. INSERT很慢
    SQLite可以轻松达到50k以上的插入速度。但是transactions速度仅为每秒60次左右(7200rpm)
    使用 BEGIN/COMMIT 包围INSERT语句可以使其成为单一事务。
    或者可以使用PRAGMA synchronous=OFF 让SQLite在写入磁盘前就继续执行。但如果遭遇断电等情况就会发生数据丢失。
  12. SQLite的UNIQUE解读同Oracle/MySQL/PostgreSQL一样,是不能为NULL的(另一种解读如SQLServer则是在非NULL子集中判断是否有重复)

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读