1、问题概述?
在python中我们主要使用三种方式操作数据库:
第一种:使用pymysql,PyMysql是一个纯 Python 实现的MySQL客户端库,允许你在Python 程序中与 MySQL 数据库进行交互,目前支持python2.x和python3.x。
第二种:使用MySQLdb进行操作,但是目前支持python2.x,不直接支持python3.x。
2、安装pymysql库
通过pip命令直接安装,比较简单,pip命令是nodejs自带的命令。如果没有安装nodejs请点击下面的链接:
https://blog.youkuaiyun.com/tangshiyilang/article/details/130355207
【安装pymysql命令】
有些人的安装命令可能是pip3命令。有时候可能提示你的pip版本低,按照提示升级就行了。
pip install pymysql
3、pymysql如何操作数据库
3.1、通过pymysql查询数据库中的数据
def selectDatabase(id):
conn = pymysql.connect(host='ip', user='root', passwd='123', port=3306, db='test', charset='utf8')
cursor = conn.cursor() #创建游标对象
sql = 'select * from from where id="' +id + '"'
cursor.execute(sql) #执行查询你语句
list = cursor.fetchall() #提取数据
conn.close() #关闭连接
for data in list: #循环打印数据
print(data)
if len(list) == 0:# 如果长度为0,退出程序
exit()
return list #返回查询结果
3.2、通过pymysql修改数据中的数据
def updateDatabase(id,name):
conn = pymysql.connect(host='ip', user='root', passwd='123', port=3306, db='test', charset='utf8')
cursor = conn.cursor()#创建游标对象
currentTime=time.strftime('%Y-%m-%d') #获取当前时间
sql = 'update studnet set name="'+name+'",date="'+ currentTime +'" where id="' +id+ '" '
cursor.execute(sql) #执行sql语句
conn.commit() #提交,增删改动作需要执行commit,否则数据不生效。
conn.close() #关闭连接
3.3、通过pymysql删除数据库中的数据
def updateDatabase():
conn = pymysql.connect(host='ip', user='root', passwd='123', port=3306, db='test', charset='utf8')
cursor = conn.cursor()
sql1 = 'delete from student where id="' +id+ '"'
cursor.execute(sql1)
try:
conn.commit()
print('删除数据成功')
except Exception as e:
print("数据删除失败")
conn.rollback()
finally:
cursor.close()
conn.close()
3.4、通过pymyql向数据库中添加数据
def insertDatabase(id,name):
conn = pymysql.connect(host='ip', user='root', passwd='123', port=3306, db='test', charset='utf8')
cursor = conn.cursor()
mark=str(mark)
sql='INSERT into student (id,name) values("' +id+ '","' +name+ '") '
cursor.execute(sql2)
conn.commit()
3.5、pymysql同时操作多条sql数据
具体sql根据实际需要填写即可
def test():
conn = pymysql.connect(host='ip', user='root', passwd='123', port=3306, db='test', charset='utf8')
cursor = conn.cursor()
sql1='delete …..'
cursor.execute(sql1)
sql2 = 'update …..'
cursor.execute(sql2)
sql3 = 'insert ……'
cursor.execute(sql3)
try:
conn.commit()
print('删除数据成功')
except Exception as e:
print("数据删除失败")
conn.rollback()
finally:
cursor.close()
conn.close()
637

被折叠的 条评论
为什么被折叠?



