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根据文件大小打log日志
Oct 09 Python
详细解读Python中的__init__()方法
May 02 Python
Python Numpy 数组的初始化和基本操作
Mar 13 Python
基于python批量处理dat文件及科学计算方法详解
May 08 Python
Python 调用PIL库失败的解决方法
Jan 08 Python
Python字典遍历操作实例小结
Mar 05 Python
python NumPy ndarray二维数组 按照行列求平均实例
Nov 26 Python
Python找出列表中出现次数最多的元素三种方式
Feb 24 Python
为什么python比较流行
Jun 19 Python
用Python制作mini翻译器的实现示例
Aug 17 Python
python实现xml转json文件的示例代码
Dec 30 Python
python读取mnist数据集方法案例详解
Sep 04 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
PHP中header和session_start前不能有输出原因分析
2013/01/11 PHP
PHP图像裁剪缩略裁切类源码及使用方法
2016/01/07 PHP
javascript + jquery实现定时修改文章标题
2014/03/19 Javascript
node.js中的url.resolve方法使用说明
2014/12/10 Javascript
关于Javascript加载执行优化的研究报告
2014/12/16 Javascript
JavaScript获取Url里的参数
2014/12/18 Javascript
jQuery中clearQueue()方法用法实例
2014/12/29 Javascript
JavaScript判断FileUpload控件上传文件类型
2015/09/28 Javascript
JavaScript实现输入框(密码框)出现提示语
2016/01/12 Javascript
JS实现table表格数据排序功能(可支持动态数据+分页效果)
2016/05/26 Javascript
判断输入的字符串是否是日期格式的简单方法
2016/07/11 Javascript
让DIV的滚动条自动滚动到最底部的3种方法(推荐)
2016/09/24 Javascript
jQuery手风琴的简单制作
2017/05/12 jQuery
详解nodeJS之二进制buffer对象
2017/06/03 NodeJs
Vue的MVVM实现方法
2017/08/16 Javascript
网页爬虫之cookie自动获取及过期自动更新的实现方法
2018/03/06 Javascript
JS中‘hello’与new String(‘hello’)引出的问题详解
2018/08/14 Javascript
Python中的包和模块实例
2014/11/22 Python
Python描述器descriptor详解
2015/02/03 Python
Django框架教程之正则表达式URL误区详解
2018/01/28 Python
Python3 安装PyQt5及exe打包图文教程
2019/01/08 Python
Python ATM功能实现代码实例
2020/03/19 Python
Django admin组件的使用
2020/10/24 Python
基督教卡片、励志礼品、家居装饰等:DaySpring
2018/10/12 全球购物
科颜氏印度官网:Kiehl’s印度
2021/02/20 全球购物
写出一个方法实现冒泡排序
2016/07/08 面试题
机关工会开展学习雷锋活动总结
2014/03/01 职场文书
求职简历自我评价范例
2014/03/12 职场文书
工商管理自荐书
2014/07/06 职场文书
2014小学一年级班主任工作总结
2014/12/05 职场文书
社团招新宣传语
2015/07/13 职场文书
手术室消毒隔离制度
2015/08/05 职场文书
2016年“11.11”光棍节活动总结
2016/04/05 职场文书
聘任书的格式及模板
2019/10/28 职场文书
Python进阶学习之带你探寻Python类的鼻祖-元类
2021/05/08 Python
解决Vmware虚拟机安装centos8报错“Section %Packages Does Not End With %End. Pane Is Dead”
2022/06/01 Servers