Python操作MySQL数据库的示例代码


Posted in Python onJuly 13, 2020

1. MySQL Connector

1.1 创建连接

import mysql.connector
 config={
   "host":"localhost","port":"3306",
   "user":"root","password":"password",
   "database":"demo"
 }
 con=mysql.connector.connect(**config)
 import mysql.connector
 config={
   "host":"localhost","port":"3306",
   "user":"root","password":"password",
   "database":"demo"
 }
 con=mysql.connector.connect(**config)

1.2 Cursor

import mysql.connector
 con=mysql.connector.connect(
   host="localhost",port="3306",
   user="root",password="password",
   database="demo"
 )
 cursor=con.cursor()
 sql="SELECT empno,job,sal FROM t_bonus;"
 cursor.execute(sql)
 print(type(cursor))
 for i in cursor:
   print(i)
 con.close()
 
 Result:
   <class 'mysql.connector.cursor_cext.CMySQLCursor'>
   (7369, 'CLERK', Decimal('8000.00'))
   (7499, 'SALESMAN', Decimal('1600.00'))
   (7521, 'SALESMAN', Decimal('1250.00'))
   (7566, 'MANAGER', Decimal('2975.00'))
   (7654, 'SALESMAN', Decimal('1250.00'))
   (7698, 'MANAGER', Decimal('2850.00'))
   (7782, 'MANAGER', Decimal('2450.00'))
   (7788, 'ANALYST', Decimal('3000.00'))
   (7839, 'PRESIDENT', Decimal('5000.00'))
   (7844, 'SALESMAN', Decimal('1500.00'))
   (7900, 'CLERK', Decimal('950.00'))
   (7902, 'ANALYST', Decimal('3000.00'))
   (7934, 'CLERK', Decimal('1300.00'))

1.3 SQL注入攻击

  1. username=1 OR 1=1 password=1 OR 1=1
  2. 在使用字符串直接拼接时OR之前不管对错,与OR结合都为true
  3. 解决方法——预编译(也可以提高速度)

1.4 事务管理和异常处理

sql连接和使用异常处理异常

import mysql.connector
 try:
   con=mysql.connector.connect(
     host="localhost",port="3306",
     user="root",password="password",
     database="demo"
   )
   con.start_transaction()
   cursor=con.cursor()
   sql="INSERT INTO t_dept(deptno,dname,loc) VALUES(%s,%s,%s);"
   cursor.execute(sql,(60,"SALES","HUBAI"))
   con.commit()
 except Exception as e:
   if "con" in dir():
     con.rollback()
   print(e)
 finally:
   if "con" in dir():
     con.close()

1.5 删除数据

import mysql.connector,mysql.connector.pooling
 config={
   "host": "localhost", "port": "3306",
   "user": "root", "password": "password",
   "database": "demo"
 }
 try:
   pool=mysql.connector.pooling.MySQLConnectionPool(**config,pool_size=5)
   con=pool.get_connection()
   con.start_transaction()
   cursor = con.cursor()
   sql = "DELETE FROM t_dept WHERE deptno=%s"
   cursor.execute(sql, (70,))
   con.commit()
 except Exception as e:
   if "con" in dir():
     con.rollback()
   print(e)
 # do not need to close con

executemany() 反复执行一条SQL语句

import mysql.connector,mysql.connector.pooling
 config={
   "host": "localhost", "port": "3306",
   "user": "root", "password": "password",
   "database": "demo"
 }
 try:
   pool=mysql.connector.pooling.MySQLConnectionPool(**config,pool_size=5)
   con=pool.get_connection()
   con.start_transaction()
   cursor = con.cursor()
   sql = "INSERT INTO t_dept(deptno,dname,loc) VALUES(%s,%s,%s);"
   date=[[70,"SALES","BEIJING"],[80,"ACTOR","SHANGHAI"]]
   cursor.executemany(sql, date)
   con.commit()
 except Exception as e:
   if "con" in dir():
     con.rollback()
   print(e)
 # do not need to close con

2. 数据库连接池

  1. 数据库的连接是昂贵的,一个连接要经过TCP三次握手,四次挥手,而且一台计算机的最大线程数也是有限的
  2. 数据库连接池技术就是先创建好连接,再直接拿出来使用
import mysql.connector,mysql.connector.pooling
 config={
   "host": "localhost", "port": "3306",
   "user": "root", "password": "password",
   "database": "demo"
 }
 try:
   pool=mysql.connector.pooling.MySQLConnectionPool(**config,pool_size=5)
   con=pool.get_connection()
   con.start_transaction()
   cursor = con.cursor()
   sql = "INSERT INTO t_dept(deptno,dname,loc) VALUES(%s,%s,%s);"
   cursor.execute(sql, (70, "SALES", "HUBAI"))
   con.commit()
 except Exception as e:
   if "con" in dir():
     con.rollback()
   print(e)
 # do not need to close con

以上就是Python操作MySQL数据库的示例代码的详细内容,更多关于Python操作MySQL数据库的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
python生成器的使用方法
Nov 21 Python
Python模拟登陆实现代码
Jun 14 Python
python实现上传下载文件功能
Nov 19 Python
解决Python网页爬虫之中文乱码问题
May 11 Python
Python绘制KS曲线的实现方法
Aug 13 Python
在mac下查找python包存放路径site-packages的实现方法
Nov 06 Python
python自动发邮件总结及实例说明【推荐】
May 31 Python
在SQLite-Python中实现返回、查询中文字段的方法
Jul 17 Python
Mac 使用python3的matplot画图不显示的解决
Nov 23 Python
你需要学会的8个Python列表技巧
Jun 24 Python
学python最电脑配置有要求么
Jul 05 Python
python批量检查两个对应的txt文件的行数是否一致的实例代码
Oct 31 Python
Python基于正则表达式实现计算器功能
Jul 13 #Python
python输出结果刷新及进度条的实现操作
Jul 13 #Python
python实现图像外边界跟踪操作
Jul 13 #Python
Python实现打包成库供别的模块调用
Jul 13 #Python
Python numpy矩阵处理运算工具用法汇总
Jul 13 #Python
解决pyinstaller 打包exe文件太大,用pipenv 缩小exe的问题
Jul 13 #Python
Python使用pyexecjs代码案例解析
Jul 13 #Python
You might like
人大复印资料处理程序_补充篇
2006/10/09 PHP
php foreach 参数强制类型转换的问题
2010/12/10 PHP
如何用php生成扭曲及旋转的验证码图片
2013/06/07 PHP
php实现随机生成易于记忆的密码
2015/06/19 PHP
PHP大文件分割上传 PHP分片上传
2017/08/28 PHP
php常用日期时间函数实例小结
2019/07/04 PHP
50个优秀经典PHP算法大集合 附源码
2020/08/26 PHP
jquery 模板的应用示例
2013/11/12 Javascript
jQuery源码解读之addClass()方法分析
2015/02/20 Javascript
js实现同一页面可多次调用的图片幻灯切换效果
2015/02/28 Javascript
jQuery实现在textarea指定位置插入字符或表情的方法
2015/03/11 Javascript
JS实现弹性菜单效果代码
2015/09/07 Javascript
javascript实现在指定元素中垂直水平居中
2015/09/13 Javascript
使用递归遍历对象获得value值的实现方法
2016/06/14 Javascript
Javascript数组中push方法用法分析
2016/10/31 Javascript
JavaScript实现二分查找实例代码
2017/02/22 Javascript
ionic2打包android时gradle无法下载的解决方法
2017/04/05 Javascript
vuejs使用axios异步访问时用get和post的实例讲解
2018/08/09 Javascript
vue2.0+vue-router构建一个简单的列表页的示例代码
2019/02/13 Javascript
[02:51]2014DOTA2 TI小组赛总结中国军团全部进军钥匙球馆
2014/07/15 DOTA
python搜索指定目录的方法
2015/04/29 Python
python交互式图形编程实例(三)
2017/11/17 Python
Python3实现的判断环形链表算法示例
2019/03/07 Python
在python3中实现更新界面
2020/02/21 Python
python3中datetime库,time库以及pandas中的时间函数区别与详解
2020/04/16 Python
Python加速程序运行的方法
2020/07/29 Python
保加利亚手表、香水、化妆品和珠宝购物网站:Brasty.bg
2020/04/22 全球购物
编程实现去掉XML的重复结点
2014/05/28 面试题
护理专业本科生自荐信
2013/10/01 职场文书
自我鉴定注意事项
2014/01/19 职场文书
幼儿园家长寄语
2014/04/02 职场文书
初中作文评语大全
2014/04/23 职场文书
户籍证明格式
2014/09/15 职场文书
保险公司客户经理岗位职责
2015/04/09 职场文书
导游词之无锡丝业博物馆
2019/11/12 职场文书
漫画《催眠麦克风-Dawn Of Divisions》第二卷PV公开
2022/04/05 日漫