百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

干货!python与MySQL数据库的交互实战

off999 2024-10-12 06:15 29 浏览 0 评论



安装pymysql库

如果你想要使用python操作MySQL数据库,就必须先要安装pymysql库,这个

库的安装很简单,直接使用pip install pymysql;

入门Python其实很容易,但是我们要去坚持学习,每一天坚持很困难,我相信很多人学了一个星期就放弃了,为什么呢?其实没有好的学习资料给你去学习,你们是很难坚持的,这是小编收集的Python入门学习资料关注,转发,私信小编“01”,即可免费领取!希望对你们有帮助


假如上面这种方式还是安装不上,就用如下链接找一个合适的安装包,进行安

装,这个就不细说了。https://www.lfd.uci.edu/~gohlke/pythonlibs/


使用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连接器的编码。


2)python连接mysql的语法


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


最基本的参数是host,user,password和port,必须要有。剩下两个参数根据你自己的情况决定是否使用。


host指的是mysql服务器安装在哪里,由于我的mysql就是安装在本机上,因此这里可以写localhost,我也可以写成主机名或者主机ip。


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()

结果如下:

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

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


execute(query, args):执行单条sql语句,接收的参数为sql语句本身和使用的参数列表,返回值为受影响的行数;


executemany(query, args):执行单条sql语句,但是重复执行参数列表里的参数,返回值为受影响的行数;

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


fetchone():返回一条结果行;


fetchmany(size):接收size条返回结果行。如果size的值大于返回的结果行的数量,则会返回cursor.arraysize条数据;


fetchall():接收全部的返回结果行;

创建表(建)

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中,将代码进行多次换行的时候,最好使用“三引号”。


查询数据(查)
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()

结果如下:


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()

结果如下:


注:还有一个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)

结果如下:


插入数据(增)
一次性插入一条数据

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()

一次性插入一条数据

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()

一次性插入多条数据

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()

更新数据(改)

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()

删除数据(删)

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()


总结如下:


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


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

相关推荐

Python Flask 容器化应用链路可观测

简介Flask是一个基于Python的轻量级Web应用框架,因其简洁灵活而被称为“微框架”。它提供了Web开发所需的核心功能,如请求处理、路由管理等,但不会强制开发者使用特定的工具或库。...

Python GUI应用开发快速入门(python开发软件教程)

一、GUI开发基础1.主流GUI框架对比表1PythonGUI框架比较框架特点适用场景学习曲线Tkinter内置库,简单小型应用,快速原型平缓PyQt功能强大,商用许可专业级桌面应用陡峭PySi...

【MCP实战】Python构建MCP应用全攻略:从入门到实战!

实战揭秘:Python Toga 打造跨平台 GUI 应用的神奇之旅

在Python的世界里,GUI(图形用户界面)开发工具众多,但要找到一款真正跨平台、易于使用且功能强大的工具并不容易。今天,我们就来深入探讨一下Toga——一款Python原生、操作系统原...

python应用目录规划(python的目录)

Python大型应用目录结构规划(企业级最佳实践)核心原则模块化:按业务功能拆分,高内聚低耦合可扩展性:支持插件机制和动态加载环境隔离:清晰区分开发/测试/生产环境自动化:内置标准化的构建测试部署流...

Python图形化应用开发框架:PyQt开发简介

PyQt概述定义:PyQt是Python绑定Qt框架的工具集,用于开发跨平台GUI应用程序原理:通过Qt的C++库提供底层功能,PyQt使用SIP工具生成Python绑定特点:支持Windows/ma...

[python] 基于PyOD库实现数据异常检测

PyOD是一个全面且易于使用的Python库,专门用于检测多变量数据中的异常点或离群点。异常点是指那些与大多数数据点显著不同的数据,它们可能表示错误、噪声或潜在的有趣现象。无论是处理小规模项目还是大型...

Python、Selenium 和 Allure 进行 UI 自动化测试的简单示例脚本

环境准备确保你已经安装了以下库:SeleniumAllurepytest你可以使用以下命令安装所需库:pipinstallseleniumallure-pytestpytest示例代码下面的代...

LabVIEW 与 Python 融合:打造强大测试系统的利器

在现代测试系统开发领域,LabVIEW和Python各自凭借独特优势占据重要地位。LabVIEW以图形化编程、仪器控制和实时系统开发能力见长;Python则凭借丰富的库资源、简洁语法和强大数...

软件测试进阶之自动化测试——python+appium实例

扼要:1、了解python+appium进行APP的自动化测试实例;2、能根据实例进行实训操作;本课程主要讲述用python+appium对APP进行UI自动化测试的例子。appium支持Androi...

Python openpyxl:读写样式Excel一条龙,测试报表必备!

无论你是测试工程师、数据分析师,还是想批量导出Excel的自动化工作者,只需一个库openpyxl,即可高效搞定Excel的各种需求!为什么选择openpyxl?支持.xlsx格式...

Python + Pytest 测试框架——数据驱动

引言前面已经和大家介绍过Unittest测试框架的数据驱动框架DDT,以及其实现原理。今天和大家分享的是Pytest测试框架的数据驱动,Pytest测试框架的数据驱动是由pytest自...

这款开源测试神器,圆了我玩游戏不用动手的梦想

作者:HelloGitHub-Anthony一天我在公司用手机看游戏直播,同事问我在玩什么游戏?我和他说在看直播,他恍然大悟:原来如此,我还纳闷你玩游戏,咋不用动手呢。。。。一语惊醒梦中人:玩游戏不用...

Python单元测试框架对比(pycharm 单元测试)

一、核心框架对比特性unittest(标准库)pytest(主流第三方)nose2(unittest扩展)doctest(文档测试)安装Python标准库pipinstallpytestp...

利用机器学习,进行人体33个2D姿态检测与评估

前几期的文章,我们分享了人脸468点检测与人手28点检测的代码实现过程,本期我们进行人体姿态的检测与评估通过视频进行人体姿势估计在各种应用中起着至关重要的作用,例如量化体育锻炼,手语识别和全身手势控制...

取消回复欢迎 发表评论: