本文主要介绍一些关于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,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子集中判断是否有重复)。
【编辑推荐】
当前名称:SQLiteFAQ常见问题解答
地址分享:http://www.gawzjz.com/qtweb/news5/181605.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联