pymysql实现增删改查的操作指南(python)
作者:客官不爱喝酒 时间:2024-01-20 08:04:04
1.安装pymysql:pip install pymysql (在命令行窗口中执行)
2.卸载pymysql:pip uninstall pymysql (在命令行窗口中执行)
数据库的连接
需要注意的是port是不用引号括起来 charset是utf8不是utf-8
# 获取数据库连接对象
connection = pymysql.connect(host='localhost', port=3306, user='root', passwd='2732195202', db='book', charset='utf8')
# 获取一个游标
driver = connection.cursor()
# 执行一条sql
driver.execute("select version()")
# 获取执行sql的返回值
resultData=driver.fetchall()
print(resultData)
# 关闭数据库
connection.close()
创建数据库表
import pymysql
#获取数据库连接对象
connection = pymysql.connect(host='localhost', port=3306, user='root', passwd='2732195202', db='book', charset='utf8')
#获取一个游标
driver=connection.cursor()
# 如果该数据库存在就删除
driver.execute("drop table if exists t_emp ")
# 定义sql语句
sql=""" CREATE TABLE `t_emp` (
`id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键',
`department` varchar(20) DEFAULT NULL COMMENT '部门',
`salary` decimal(10,2) DEFAULT NULL COMMENT '工资',
`age` int(11) DEFAULT NULL COMMENT '年龄',
`sex` varchar(4) DEFAULT NULL COMMENT '性别',
PRIMARY KEY (`id`)
)ENGINE=InnoDB DEFAULT CHARSET=utf8;
"""
# 执行sql
driver.execute(sql)
# 关闭数据连接
connection.close()
向数据库中添加数据
1.需要注意的是规范sql,该写的字段都写上,不使用默认对应
2.提交事务的对象是数据库连接对象,而不是游标对象
3.pycharm连接mysql数据时,如果连接驱动是高版本,需要加上时区,jdbc:mysql://localhost/book?serverTimezone=GMT%2B8
4.如果主键是自动递增,则不能手动指定值,不能写该字段,让其自增长
# 获取数据库连接对象
connection=pymysql.connect(host='localhost',port=3306,user='root',passwd='2732195202',db='book',charset='utf8')
# 获取一个游标
driver=connection.cursor()
# 定义sql语句
sql=""" insert into t_emp(name,department,salary,age,sex)
values("tom","开发部",8000,25,"男"), ("tom","开发部",8000,25,"男")
"""
# 尝试捕捉错误
try:
# 执行SQL,并返回收影响行数
result=driver.execute(sql)
# 提交事务
connection.commit()
print("sql(insert)->error")
except:
# 如果发生错误 则回滚事务
print("sql(insert)->error")
driver.rollback()
# 关闭数据库连接
connection.close()
修改表中的数据
注意点:在操作数据库之前,需要确认是否获取连接数据库成功,并且选中了数库
2.卸载第三方库:pip uninstall pymysql
#获取数据库连接对象 autocommit=True:设置数据库自动提交
connection=pymysql.connect(host="localhost",port=3306,user='root',passwd='2732195202',db='book',charset='utf8',autocommit=True)
# 获取游标对象
driver=connection.cursor()
# 定义sql
sql="update t_emp set salary=%s,name=%s where id=%s;"
# 如果sql错误就执行回滚操作,成功就提交
try:
# 执行sql,并且返回影响的行数
result=driver.execute(sql,[6000,"admin",19])
connection.commit()
print("sql(update)->success")
except:
print("sql(update)->error")
connection.rollback()
# 关闭数据库连接对象
connection.close()
查询数据
1.项目中的.py文件不能和python库中的文件进行冲突,否则会出现异常
# 获取数据库连接对象
connection=pymysql.connect(host='localhost',port=3306,user='root',passwd='2732195202',db='book',charset='utf8')
# 获取一个游标对象
driver=connection.cursor()
#定义sql
sql="select id, name, department, salary, age, sex from t_emp where id>%s and sex=%s"
# 只能获取一次,获取多次的时候会获取到null 如果是多个参数,需要传递一个元组
try:
driver.execute(sql,(1,"女"))
# 获取所有的查询结果 返回一个元组
resultAll=driver.fetchall()
print("resultAll:", resultAll)
# 获取2条数据
resultTwo=driver.fetchmany(2)
print("resultTwo:", resultTwo)
# 获取一条数据
resultOne=driver.fetchone()
print("resultThree:", resultOne)
print("sql(select)->success")
except:
connection.rollback()
print("sql(select)->error")
# 关闭数据库连接
connection.close()
删除表中的记录
import pymysql
# 获取数据库连接对象
connection = pymysql.connect(host='localhost', port=3306, user='root', passwd='2732195202', db='book', charset='utf8')
# 获取一个游标
driver = connection.cursor()
# 定义sql
sql="delete from t_emp where id=%s"
try:
# 执行一条sql
driver.execute(sql, (21))
# 提交事务
connection.commit()
print("sql(delete)->success")
except Exception as e:
# 回滚事务
connection.rollback()
print("sql(delete)->error")
print(e)
#关闭数据库连接
connection.close()
事务操作
提交事务: connection.commit()
回滚事务: connection.rollback()
总结
来源:https://blog.csdn.net/m0_46188681/article/details/116721048
标签:pymysql,增删改查,python
0
投稿
猜你喜欢
Python实现一个简单的毕业生信息管理系统的示例代码
2023-12-20 04:40:46
Vue中ref和$refs的介绍以及使用方法示例
2023-07-02 17:00:10
Python中使用tkFileDialog实现文件选择、保存和路径选择
2022-02-17 09:35:32
Python实现修改Excel文件的元数据
2023-05-01 01:01:47
python错误调试及单元文档测试过程解析
2021-05-03 03:46:14
sql server实现在多个数据库间快速查询某个表信息的方法
2024-01-25 05:23:10
Python单元和文档测试实例详解
2023-01-01 19:08:06
PHP入门教程之面向对象的特性分析(继承,多态,接口,抽象类,抽象方法等)
2023-11-18 08:17:16
Pycharm中配置Anaconda解释器的完整步骤
2021-12-16 16:37:38
利用css的clear属性搞定广告文字环绕效果
2008-05-24 13:48:00
关于Tensorflow中的tf.train.batch函数的使用
2023-11-04 19:49:54
javascript获取select值的方法完整实例
2024-04-22 12:49:18
python输出数组中指定元素的所有索引示例
2021-11-27 02:21:09
Python 创建空的list,以及append用法讲解
2021-02-23 17:05:58
pyCharm 实现关闭代码检查
2023-05-14 18:48:01
利用Django框架中select_related和prefetch_related函数对数据库查询优化
2024-01-20 23:24:19
怎么使用pipenv管理你的python项目
2021-01-29 06:58:41
XML简易教程之四
2008-09-05 17:19:00
Win10下配置tensorflow-gpu的详细教程(无VS2015/2017)
2023-04-27 13:37:46
Python处理字符串的常用函数实例总结
2022-10-19 21:09:39