以管理员的身份登录数据库,创建数据库并赋予权限,然后再以普通用户的身份重新登录数据库客户端。
import MySQLdb
#打开数据库连接
conn=MySQLdb.connect(host="localhost",user="root",passwd="123456",db="test",charset="utf8")
# 删除数据库
conn.query("DROP DATABASE test")
# 创建数据库
conn.query("CREATE DATABASE test")
# 普通用户登录数据库客户端
conn.query("GRANT ALL ON test.* to ''@'localhost'")
conn.commit()
conn.close()
没有使用游标;一些适配器有 Connection 对象,这些对象可以使用 query() 方法执行 SQL 查询。
commit() 方法是可选的,因为 MySQL 默认开启了自动提交。重新作为普通用户登录这个新数据库,创建表,然后通过 Python 执行一些常用的 SQL 查询和命令;使用游标以及 execute() 方法。
import MySQLdb
#打开数据库连接
conn=MySQLdb.connect(host="localhost",user="root",passwd="123456",db="test",charset="utf8")
cur = conn.cursor()
cur.execute("CREATE TABLE users(login VARCHAR(8), userid INT)")
# 向数据库中添加一些行,并对其进行查询
cur.execute("INSERT INTO users VALUES('团子', '0001')")
cur.execute("INSERT INTO users VALUES('小团子', '0002')")
cur.execute("INSERT INTO users VALUES('大团子', '0003')")
cur.execute("SELECT * FROM users WHERE login LIKE '团%'")
for data in cur.fetchall():
print('%s\t%s' % data)
import MySQLdb
#打开数据库连接
conn=MySQLdb.connect(host="localhost",user="root",passwd="123456",db="test",charset="utf8")
cur = conn.cursor()
# 更新
cur.execute("UPDATE users SET userid=0010 WHERE userid=0001")
# 查询
cur.execute("SELECT * FROM users")
for data in cur.fetchall():
print('%s\t%s' % data)
# 删除字段
cur.execute("DELETE FROM users WHERE login='团子'")
# 删除表
cur.execute('DROP TABLE users')
cur.close()
conn.commit()
conn.close()