python与mysql数据库交互的实现


Posted in Python onJanuary 06, 2020

1、安装pymysql库

如果你想要使用python操作MySQL数据库,就必须先要安装pymysql库,这个库的安装很简单,直接使用pip install pymysql;进行安装。
假如上面这种方式还是安装不上,就用如下链接找一个合适的安装包进行安装,这个就不细说了,请自行百度。
https://www.lfd.uci.edu/~gohlke/pythonlibs/
学习本篇文章,最好是先看我另外一篇关于游标cursor讲解的文章,这样会有更好的效果:https://3water.com/article/177865.htm

2、使用python连接mysql数据库
1)六个常用的连接参数

  • 参数host:mysql服务器所在的主机的ip;
  • 参数user:用户名
  • 参数password:密码
  • 参数port:连接的mysql主机的端口,默认是3306
  • 参数db:连接的数据库名
  • 参数charset:当读取数据出现中文会乱码的时候,需要我们设置一下编码;我们使用python操作数据库的时候,那么python就相当于是client,我们是用这个client来操作mysql的server服务器,python3默认采用的utf8字符集,我的mysql服务器默认采用latin1字符集,因此mysql中创建的每张表,都是建表的时候加了utf8编码的,因此这里设置的应该就是connection连接器的编码。

什么是connection?可以参考我的另外一篇文章学习。
https://3water.com/article/177872.htm

2)python连接mysql的语法

import pymysql 
db = pymysql.connect(host='localhost',user='root',password='123456',port=3306,db='spiders',charset=' utf8')
  1. 最基本的参数是host,user,password和port,必须要有。剩下两个参数根据你自己的情况决定是否使用。
  2. host指的是mysql服务器安装在哪里,由于我的mysql就是安装在本机上,因此这里可以写localhost,我也可以写成主机名或者主机ip。
  3. db指的是你要操作的是哪一个数据库,在进行数据库连接的时候,最好加上这个参数。

3)一个简单的热身案例

# 导包
import pymysql 
# 使用pymysql连接上mysql数据库服务器,创建了一个数据库对象;
db = pymysql.connect(host='localhost',user='root', password='123456',
     port=3306, db='huangwei', charset='utf8')
# 开启mysql的游标功能,创建一个游标对象;    
cursor = db.cursor()
# 要执行的SQL语句;
sql = "select * from student"
# 使用游标对象执行SQL语句;
cursor.execute(sql)
# 使用fetchone()方法,获取返回的结果,但是需要用变量保存返回结果;
data = cursor.fetchone()
print(data)
# 断开数据库的连接,释放资源;
db.close()

结果如下:

python与mysql数据库交互的实现

3、cursor游标对象的一些常用方法

1)cursor用来执行命令的方法

  1. execute(query, args):执行单条sql语句,接收的参数为sql语句本身和使用的参数列表,返回值为受影响的行数;
  2. executemany(query, args):执行单挑sql语句,但是重复执行参数列表里的参数,返回值为受影响的行数;

2)cursor用来接收返回值的方法

  1. fetchone():返回一条结果行;
  2. fetchmany(size):接收size条返回结果行。如果size的值大于返回的结果行的数量,则会返回cursor.arraysize条数据;
  3. fetchall():接收全部的返回结果行;

4、创建表

import pymysql 
db = pymysql.connect(host='localhost',user='root', password='123456',port=3306, db='huangwei', charset='utf8')

# 创建一个游标对象;
cursor = db.cursor()
 
# 建表语句;
sql = """
  create table person(
   id int auto_increment primary key not null,
   name varchar(10) not null,
   age int not null
  )charset=utf8
  """

# 执行sql语句;
cursor.execute(sql)
 
# 断开数据库的连接;
db.close()

注意:你在mysql中sql语句怎么写,在这里就怎么写。还有一个细节需要注意的是,在python中,将代码进行多次换行的时候,最好使用“三引号”。

5、查询数据…查

1)fetchone():一次获取一条记录

import pymysql
 
db = pymysql.connect(host='localhost',user='root',db='huangwei',password='123456',port=3306,charset='utf8')
      
cursor = db.cursor()

cursor.execute('select count(*) from person')
aa = cursor.fetchone()
print(aa)
cursor.execute('select name,age from person') 
for i in range(aa[0]):
 a,b = cursor.fetchone()
 c = "我的名字叫{},今年{}岁".format(a,b)
 display(c)
db.close()

结果如下:

python与mysql数据库交互的实现

2)fetchall():一次获取所有记录

import pymysql
 
db = pymysql.connect(host='localhost',user='root',db='huangwei',password='123456',port=3306,charset='utf8')
      
cursor = db.cursor()

cursor.execute('select name,age from person')
aa = cursor.fetchall()
# print(aa)
for a,b in aa:
 c = "我的名字叫{},今年{}岁".format(a,b)
 display(c)
db.close()

结果如下:

python与mysql数据库交互的实现

注:还有一个fetchmany()方法,用于一次性获取指定条数的记录,请自行下去研究。

3)使用pandas中的read_sql()方法,将提取到的数据直接转化为DataFrame进行操作

import pymysql 
import pandas as pd

db = pymysql.connect(host='localhost',user='root',db='huangwei',password='123456',port=3306,charset='utf8')
cursor = db.cursor()

df1 = pd.read_sql("select * from student where ssex='男'",db)
display(df1)

df2 = pd.read_sql("select * from student where ssex='女'",db)
display(df2)

结果如下:

python与mysql数据库交互的实现

6、插入数据…增

1)一次性插入一条数据

import pymysql

db = pymysql.connect(host='localhost',user='root', password='123456',port=3306, db='huangwei', charset='utf8')
 
cursor = db.cursor()
 
# mysql中SQL语句怎么写,这里就怎么写;
name = "猪八戒"
age = 8000
sql = 'insert into person(name,age) values ("猪八戒",8000)'

try:
 cursor.execute(sql)
 db.commit()
 print("插入成功")
except:
 print("插入失败")
 db.rollback()
db.close()

1.1)一次性插入一条数据

import pymysql
 
db = pymysql.connect(host='localhost',user='root', password='123456',port=3306, db='huangwei', charset='utf8')
 
cursor = db.cursor()
 
# 插入数据
sql = 'insert into person(name,age) values(%s,%s)'
try:
 cursor.execute(sql,('孙悟空',100000))
 db.commit()
 print("插入成功")
except:
 print("插入失败")
 db.rollback()
db.close()

2)一次性插入多条数据

import pymysql
 
db = pymysql.connect(host='localhost',user='root', password='123456',port=3306, db='huangwei', charset='utf8')
 
cursor = db.cursor()
 
# 插入数据
sql = 'insert into person(name,age) values(%s,%s)'
# 注意:(('牛魔王',9000),('铁扇公主',8000),('玉皇大帝',6000))也可以,小括号都可以换为中括号
datas = [('牛魔王',9000),('铁扇公主',8000),('玉皇大帝',6000)]
try:
 cursor.executemany(sql,datas)
 db.commit()
 print("插入成功")
except:
 print("插入失败")
 db.rollback()
db.close()

总结如下:

① pymysql模块是默认开启mysql的事务功能的,因此,进行 “增” “删” "改"的时候,一定要使用db.commit()提交事务,否则就看不见所插入的数据。

② 进行 “增”、“删”、"改"的时候,一定要使用try…except…语句,因为万一没插入成功,其余代码都无法执行。当语句执行不成功,我们就db.rollback()回滚到操作之前的状态;当语句执行成功,我们就db.commit()提交事务。

7、更新数据…改

import pymysql
 
db = pymysql.connect(host='localhost',user='root', password='123456',port=3306, db='huangwei', charset='utf8')
 
cursor = db.cursor()
 
# 更新数据
sql = 'update person set age=%s where name=%s'
try:
 cursor.execute(sql,[90000,"玉皇大帝"])
 db.commit()
 print("更新成功")
except:
 print("更新失败")
 db.rollback()
db.close()

8、删除数据…删

import pymysql
 
db = pymysql.connect(host='localhost',user='root', password='123456',port=3306, db='huangwei', charset='utf8')
 
cursor = db.cursor()
 
# 删除数据
sql = 'delete from person where age=8000'
try:
 cursor.execute(sql)
 db.commit()
 print("删除成功")
except:
 print("删除失败")
 db.rollback()
db.close()

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python访问sqlserver示例
Feb 10 Python
Python程序设计入门(2)变量类型简介
Jun 16 Python
Python压缩和解压缩zip文件
Feb 14 Python
详解python之简单主机批量管理工具
Jan 27 Python
python根据unicode判断语言类型实例代码
Jan 17 Python
详解Python传入参数的几种方法
May 16 Python
python实现的Iou与Giou代码
Jan 18 Python
Python实现加密接口测试方法步骤详解
Jun 05 Python
python中random.randint和random.randrange的区别详解
Sep 20 Python
使用Python实现音频双通道分离
Dec 25 Python
学点简单的Django之第一个Django程序的实现
Feb 24 Python
python爬虫scrapy框架之增量式爬虫的示例代码
Feb 26 Python
win10系统下python3安装及pip换源和使用教程
Jan 06 #Python
基于python实现文件加密功能
Jan 06 #Python
Pytorch 实现冻结指定卷积层的参数
Jan 06 #Python
如何使用python实现模拟鼠标点击
Jan 06 #Python
pytorch 实现查看网络中的参数
Jan 06 #Python
Python3 虚拟开发环境搭建过程(图文详解)
Jan 06 #Python
Pytorch根据layers的name冻结训练方式
Jan 06 #Python
You might like
基于数据库的在线人数,日访问量等统计
2006/10/09 PHP
PHP UTF8编码内的繁简转换类
2009/07/20 PHP
php打印输出棋盘的实现方法
2014/12/23 PHP
CodeIgniter框架钩子机制实现方法【hooks类】
2018/08/21 PHP
JS是否可以跨文件同时控制多个iframe页面的应用技巧
2007/12/16 Javascript
JQuery性能优化的几点建议
2014/05/14 Javascript
jQuery实现的数值范围range2dslider选取插件特效多款代码分享
2015/08/27 Javascript
jquery实现鼠标悬浮停止轮播特效
2020/08/20 Javascript
Jquery通过ajax请求NodeJS返回json数据实例
2016/11/08 NodeJs
Vue.js如何实现路由懒加载浅析
2017/08/14 Javascript
jQuery实现基本淡入淡出效果的方法详解
2018/09/05 jQuery
js实现动态增加文件域表单功能
2018/10/22 Javascript
jquery中attr、prop、data区别与用法分析
2019/09/25 jQuery
vue使用swiper.js重叠轮播组建样式
2019/11/14 Javascript
在vue中获取wangeditor的html和text的操作
2020/10/23 Javascript
[40:04]Secret vs Infamous 2019国际邀请赛淘汰赛 败者组 BO3 第二场 8.23
2019/09/05 DOTA
解析Python中的__getitem__专有方法
2016/06/27 Python
在Python中分别打印列表中的每一个元素方法
2018/11/07 Python
python3 tcp的粘包现象和解决办法解析
2019/12/09 Python
Python 时间戳之获取整点凌晨时间戳的操作方法
2020/01/28 Python
Django 设置多环境配置文件载入问题
2020/02/25 Python
突袭HTML5之Javascript API扩展1—Web Worker异步执行及相关概述
2013/01/31 HTML / CSS
size?瑞典:英国伦敦的球鞋精品店
2018/03/01 全球购物
什么是"引用"?申明和使用"引用"要注意哪些问题?
2016/03/03 面试题
纪检干部先进事迹材料
2014/08/23 职场文书
2014党员学习《反腐倡廉警示教育读本》思想汇报
2014/09/13 职场文书
本科毕业论文指导教师评语
2014/12/30 职场文书
高三语文复习计划
2015/01/19 职场文书
新农村建设指导员工作总结
2015/08/13 职场文书
2015年大学组织委员个人工作总结
2015/10/23 职场文书
品牌形象定位,全面分析
2019/07/23 职场文书
导游词之襄阳古城
2019/09/27 职场文书
导游词之重庆渣滓洞
2020/01/08 职场文书
分布式架构Redis中有哪些数据结构及底层实现原理
2022/03/13 Redis
悬疑名作《朋友游戏》动画无字ED宣传片 新角色公开
2022/04/13 日漫
Redis配置外网可访问(redis远程连接不上)的方法
2022/12/24 Redis