数据库
SQLite
SQLite是一种嵌入式关系型数据库, 它的数据库就是一个文件. Python本身就内置了SQLite3, 所以在Python中使用SQLite不需要装任何东西, 直接导入它的驱动就可以了. SQLite的特点是轻量级, 但是不能承受高并发访问.
要操作SQLite, 要弄清楚几个概念: 首先, 需要连接到数据库, 称之为connection. 连接到数据库后, 需要打开游标, 称之为cursor. 通过cursor执行SQL语句. 然后提交事务, 保存更改. 最后关闭游标和连接.
例子
MySQL
MySQL是世界上最广泛使用的关系型数据库. 它能够承受高并发访问, 所占用的内存也很大.
要操作MySQL, 需要安装MySQL的驱动, pip install mysql-connector-python --allow-external mysql-connector-python
. Python的数据库API定义都是通用的, 因此, 操作MySQL的代码和操作SQLite的类似.
例子
定义:
impoort mysql.connector
conn = mysql.connector.connect(user='root', password='password', database='test')
cursor = conn.cursor()
cursor.execute('create table user (id varchar(20) primary key, name varchar(20))')
cursor.execute('insert into user (id, name) values (%s, %s)', ['1', 'wenzexu'])
print(cursor.rowcount)
conn.commit()
cursor.close()
cursor = conn.cursor()
cursor.execute('select * from user where id = %s', ('1',))
values = cursor.fetchall()
print(values)
cursor.close()
conn.close()
执行:
-
使用SQLite—廖雪峰的官方网站. (n.d.). From https://www.liaoxuefeng.com/wiki/1016959663602400/1017801751919456 ↩
-
使用MySQL. (n.d.). From https://www.liaoxuefeng.com/wiki/1016959663602400/1017802264972000 ↩