SQLite FAQ常见问题解答

数据库 其他数据库
本文主要介绍了SQLite FAQ一些常见的问题,希望会对读者有所帮助。

本文主要介绍一些关于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子集中判断是否有重复)。

【编辑推荐】

  1. 嵌入式数据库Sqlce读取数据过程简介
  2. 如何不使用数据库缓存,还达到实时更新
  3. 微软WP7本地数据库之SQLite编程技巧
  4. 微软WP7本地数据库之Sterling编程技巧

 

责任编辑:赵鹏 来源: CSDN博客
相关推荐

2011-08-09 15:10:00

SQLite

2013-11-03 22:59:07

SiteAppFAQ

2010-09-13 14:43:47

无线技术常见问题

2009-10-13 14:56:00

CCNA培训

2023-10-10 08:01:13

2010-05-12 17:04:20

BlackBerry开

2010-12-27 14:50:16

Windows 部署服

2011-07-21 11:19:51

JAVA

2015-06-30 12:39:33

公有云问题解答

2017-06-12 15:51:11

数据中心布线运维

2011-05-10 15:30:22

SEO

2013-05-23 09:49:49

Chrome for google

2013-03-04 13:58:10

2010-07-28 11:25:08

Flex滚动条

2023-10-11 10:38:53

智能卫生间物联网

2020-11-10 23:06:38

物联网智能产品开发IOT

2020-10-16 08:24:40

物联网网关物联网IOT

2020-10-16 19:23:50

物联网网关物联网IOT

2010-08-19 10:44:47

DB2 常见问题

2009-09-02 17:14:12

邮件服务器
点赞
收藏

51CTO技术栈公众号