SQLite内存数据库与硬盘数据库

SQLite是一个非常方便好用的嵌入式数据库,没有独立的进程,随着应用程序的进程一起启动。

它可以选择是内存数据库还是硬盘数据库,通常在内存中进行数据方面的操作比硬盘上的操作快几个数量级。

在特定环境下,可以先在内存中操作数据库,然后再将数据持久化到硬盘上。

具体代码如下:

#encoding=utf-8
import sqlite3
import StringIO
def query(db,sql):
    cur = db.cursor()
    cur.execute(sql)
    for row in cur:
        print row
    cur.close()
def execute_sql(db,sql):
    cur = db.cursor()
    cur.execute(sql)
    cur.close()
    db.commit()
if __name__=='__main__':
    #use memory database
    db = sqlite3.connect(':memory:')
    sql1 = "create table tb_memory(id integer primary key,name text)"
    sql2 = "insert into tb_memory(name) values('aaaaaaaaaaaaaaa')"
    sql3 = "insert into tb_memory(name) values('bbbbbbbbbbbbbbb')"
    sql4 = "insert into tb_memory(name) values('ccccccccccccccc')"
    sql5 = "select * from tb_memory"
    execute_sql(db,sql1)
    execute_sql(db,sql2)
    execute_sql(db,sql3)
    execute_sql(db,sql4)
    query(db,sql5)
    print '---------------------------------------------'
    buffer = StringIO.StringIO()
    for line in db.iterdump():
        buffer.write(line)
    db.close()
    
    #execute sql script;write into disk database
    db1 = sqlite3.connect("test.db")
    cursor = db1.cursor()
    cursor.executescript(buffer.getvalue())
    cursor.close()
    db1.close()


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值