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

[经验分享] Sqlite的FAQ学习

[复制链接]

尚未签到

发表于 2016-11-29 07:24:11 | 显示全部楼层 |阅读模式
  (7) Can multiple applications or multiple instances of the same application access a single database file at the same time?
  这里面提到,sqlite允许多个应用同时操作一个数据库文件,但由于它通过fcntl函数来控制读写锁,因此不能像其它的C/S模式数据库那样(如mysql),即可以同时读也可以同时写,sqlite只允许同一时刻读,如果同一时刻写将返回SQLITE_BUSY.同时还提到了由于fcntl函数在NFS文件系统中并不能始终执行正常,因此请避免在NFS文件系统中使用sqlite.
  (8) Is SQLite threadsafe?
  这里面提到,sqlite允许多线程打开同一个数据库,并分享数据信息,但它的线程安全性需要用户来保证,一方面在linux系统中需要添加编译参数THREADSAFE ,另一方面sqlite数据库打开的指针不能在不同的线程之间传递.

Sqlite是线程安全的,通常,为了启用这一功能,Sqlite必须在编译的时候设置THREADSAFE宏为1.缺省的情况下,windows的二进制库文件是以THREADSAFE模式编译的,但linux不是.
Threadsafe在上一章节中提到过两个或多个线程可以同时打开同一个Sqlite数据库,它们可以分别使用sqlite3_open函数返回的数据库句柄,但在多个线程中如果共用一个数据库句柄是非常不安全的.
一个数据库句柄只能被一个线程使用,你决不可以在一个线程中打开数据库,然后把返回的数据库句柄传递到另一个线程中使用,这是因为在很多线程实现如Readhat9中,如果一个线程使用fcntl()函数创建了一个锁,则它不能在其它线程中销毁或修改,因此,由于Sqlite频繁的使用了fcntl这个函数来控制加锁,如果在不同线程中传递数据库句柄,则可能带来越来越多的问题。
或许有很多其它方法可以代替fcntl来实现加锁,但它们都相对复杂或难以测试,因此Sqlite目前不允许在多个线程中共享相同的数据库句柄。
在unix系统下,你不能在fork产生的进程中打开sqlite数据库,这可能会带来未知的问题。


  (9) How do I list all tables/indices contained in an SQLite database
  sqlite中可以使用.table命令查看数据库中所有表,.schema命令查看数据库中表的详细结构.对于每个数据库都会有一个系统表SQLITE_MASTER,结构如下:

CREATE TABLE sqlite_master (
  type
TEXT,         //table或者index,表明这是表还是索引.
  name
TEXT,         //表或索引的名称.
  tbl_name
TEXT,     //索引的情况下,这个字段表明该索引对应的表名称.
  rootpage
INTEGER,
  sql
TEXT           //存储表或索引创建时的sql语句.
);


 

 

而其它临时表将存储在同样结构的SQLITE_TEMP_MASTER表中.

 

(11) What is the maximum size of a VARCHAR in SQLite

 

sqlite的varchar类型对于长度是无限制的.

 

(14) I deleted a lot of data but the database file did not get any smaller. Is this a bug?

 

当删除数据库中记录时,数据文件并不会变小,而是将这部分使用过的空间记录下来,在下次进行插入操作时利用上.当然也可以使用VACUUM命令使数据库将空闲空间释放出来,但这会消耗一定时间,大约0.5S/M.

 

(16) How do I use a string literal that contains an embedded single-quote (') character?

 

使用两个'进行转义即可.

 

运维网声明 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-306837-1-1.html 上篇帖子: C#连接SQLite的...方法 下篇帖子: sqlite数据库查看操作
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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