Python进阶-MySQL

以管理员的身份登录数据库,创建数据库并赋予权限,然后再以普通用户的身份重新登录数据库客户端。

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()

原文发布于微信公众号 - 数据云团(SmartData)

原文发表时间:2019-04-23

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

扫码关注云+社区

领取腾讯云代金券