设为首页 收藏本站
查看: 805|回复: 0

[经验分享] SQLite FAQ常见问题解答

[复制链接]

尚未签到

发表于 2016-11-29 09:14:43 | 显示全部楼层 |阅读模式
本文主要介绍一些关于SQLiteFAQ 的一些常见的问题,接下来我们就开始一一介绍:
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,000
最大列数量:2000 (谁要真的用到成千上百的列,直接跳楼算了)
SQL语句最大长度:1,000,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子集中判断是否有重复)。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-306999-1-1.html 上篇帖子: flash SQLite包装类 下篇帖子: SQLite : column '_id' does not exist
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表