码迷,mamicode.com
首页 > 数据库 > 详细

【转】sqlite3.connect

时间:2020-03-03 12:49:05      阅读:96      评论:0      收藏:0      [点我收藏+]

标签:memory   处理   缺陷   测试   线程   加锁   sqli   class   amp   

conn=sqlite3.connect(‘urls.db‘)

conn=sqlite3 connect ":memory:" )

SQLite不仅可以把数据库 放在硬盘上,还可以放在内存中(sqlite3_open(":memory:", &db)),经测试,同样条件下数据库放在内存中比放在硬盘上插入记录速度快差不多3倍。但数据库放在内存中时有如下缺陷:

1、断电或程序崩溃后数据库就会消失,你需要定期Attach到硬盘上备份;

2、在内存中的数据库不能被别的进程访问(因为没名字,以后可能支持),即使在多线程下,也得使用同一句柄;

3、不支持像在硬盘上的读写互斥处理,自己加锁吧。

  看来,追求速度要付出代价啊!

 

 

 

有没有什么方法折衷一下,就是 conn=sqlite3 connect ":memory:" )使用完之后,再保存在本地呢?

 

 

记录你执行过的sql,在使用完之后再connect("memory.db"),将sql重新执行一次,就可以保存了 也不太好

【转】sqlite3.connect

标签:memory   处理   缺陷   测试   线程   加锁   sqli   class   amp   

原文地址:https://www.cnblogs.com/chanshion/p/12401570.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!