最近发现SQLite3是一个性能非常优秀的小型数据库,非常适用于当前很多业务场景,于是决定将Sqlite3集成进当前的算法服务。
使用sqlite3 创建数据库
新建一个mysqlite.db的数据库文件,创建一张conversation表,分别创建两个字段ask, answer。
import sqlite3
db = 'mysqlite.db'
conn = sqlite3.connect(db)
cur = conn.cursor()
cur.execute(
"""
CREATE TABLE IF NOT EXISTS conversation
(ask text, answer text);
"""
)
conn.commit()
conn.close()
使用sqllite3插入多条数据
在conversation表中插入多条数据
values_to_insert = [('ask1', 'answer1'), ('ask2', 'answer2')]
conn = sqlite3.connect('mysqlite.db')
cur = conn.cursor()
cur.executemany("""
INSERT INTO conversation (ask, answer) VALUES (?, ?)
""", values_to_insert)
conn.commit()
conn.close()
执行SQL操作的时候需要使用Python变量,注意不要使用Python字符串操作,这会使你的代码变得极度不安全,非常容易被SQL注入攻击,这里是几个有趣的例子https://xkcd.com/327/。