经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 数据库/运维 » MySQL » 查看文章
教你怎么用Python操作MySql数据库
来源:jb51  时间:2021/5/31 18:23:37  对本文有异议

一、关于Python操作数据库的概述

Python所有的数据库接口程序都在一定程度上遵守 Python DB-API 规范。

DB-API定义了一系列必须的对象和数据库存取方式,以便为各种底层数据库系统和多种多样的数据库接口程序提供一致的访问接口。由于DB-API 为不同的数据库提供了一致的访问接口, 在不同的数据库之间移植代码成为一件轻松的事情。

在Python中如果要连接数据库,不管是MySQL、SQL Server、PostgreSQL亦或是SQLite,使用时都是采用游标的方式。

二、一般操作流程

在这里插入图片描述

三、安装mysql的操作库

  1. $ pip3 install PyMySQL

四、基本操作

创建连接

  1. import pymysql
  2.  
  3. # 创建连接方式1
  4. db = pymysql.connect(host='localhost',
  5. user='root', password='root', db='test', port=3306)
  6. # 创建连接方式2
  7. db = pymysql.connect(dsn='localhost:test', user='root', password='root')

close()

关闭此connect对象, 关闭后无法再进行操作,除非再次创建连接。

cursor()

创建游标对象。一个游标允许用户执行数据库命令和得到查询结果。一个 Python DB-API 游标对象总是扮演游标的角色, 无论数据库是否真正支持游标。也就说,数据库接口程序必须实现游标对象。创建游标对象之后, 你就可以执行查询或其它命令(或者多个查询和多个命令), 也可以从结果集中取出一条或多条记录。

commit()

提交当前事务,执行游标对象的所有更新操作。

rollback()

取消当前事务,回滚当前游标的所有操作。

游标操作

  1. cursor = db.cursor()
  • close():关闭此游标对象
  • fetchone():得到结果集的下一行
  • fetchall():得到结果集中剩下的所有行
  • excute(sql[, args]):执行一个数据库查询或命令
  • callproc(func[,args]): 调用一个存储过程

查询操作

  1. import pymysql
  2.  
  3. db = pymysql.connect(host='localhost', user='root', password='root', db='test')
  4.  
  5. cursor = db.cursor()
  6. sql = '''select * from t_account'''
  7. try:
  8. cursor.execute(sql)
  9. # 方式1读取结果集
  10. rows = cursor.fetchall()
  11. for row in rows:
  12. print(row)
  13. # 方式2读取结果集
  14. for i in range(cursor.rowcount):
  15. result = cursor.fetchone()
  16. print(result)
  17. except Exception as e:
  18. raise e
  19. finally:
  20. cursor.close()
  21.  
  22. db.close()

添加操作

  1. import pymysql
  2.  
  3. db = pymysql.connect(host='localhost', user='root', password='root', db='test')
  4.  
  5. cursor = db.cursor()
  6. sql = '''insert into t_account values(default,'zhangsan','z',100,'张三')'''
  7. try:
  8. print(cursor.execute(sql))
  9. db.commit()
  10. except:
  11. db.rollback()
  12. finally:
  13. cursor.close()
  14.  
  15. db.close()

修改操作

  1. import pymysql
  2.  
  3. db = pymysql.connect(host='localhost', user='root', password='root', db='test')
  4.  
  5. cursor = db.cursor()
  6. sql = '''update t_account set realname = '李四' where id = '5' '''
  7. try:
  8. print(cursor.execute(sql))
  9. db.commit()
  10. except:
  11. db.rollback()
  12. finally:
  13. cursor.close()
  14.  
  15. db.close()

删除操作

  1. import pymysql
  2.  
  3. db = pymysql.connect(host='localhost', user='root', password='root', db='test')
  4.  
  5. cursor = db.cursor()
  6. sql = '''delete from t_account where id = '5' '''
  7. try:
  8. print(cursor.execute(sql))
  9. db.commit()
  10. except:
  11. db.rollback()
  12. finally:
  13. cursor.close()
  14.  
  15. db.close()

调用存储过程

  1. cursor.callproc("存储过程名称")
  2. for result in cursor.fetchall():
  3. print(result)

到此这篇关于教你怎么用Python操作MySql数据库的文章就介绍到这了,更多相关Python操作MySql内容请搜索w3xue以前的文章或继续浏览下面的相关文章希望大家以后多多支持w3xue!

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号