≡
  • 网络编程
  • 数据库
  • CMS技巧
  • 软件编程
  • PHP笔记
  • JavaScript
  • MySQL
位置:首页 > 网络编程 > Python

Python之pyMySQL实现增删改查的操作指南

人气:362 时间:2021-06-07

这篇文章主要为大家详细介绍了Python之pyMySQL实现增删改查的操作指南,具有一定的参考价值,可以用来参考一下。

感兴趣的小伙伴,下面一起跟随四海网的雯雯来看看吧!

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

pyMySQL实现增删改查的操作指南(python)

创建数据库表

代码如下:


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

pyMySQL实现增删改查的操作指南(python)

向数据库中添加数据

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


pyMySQL实现增删改查的操作指南(python)

修改表中的数据

注意点:在操作数据库之前,需要确认是否获取连接数据库成功,并且选中了数库

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

pyMySQL实现增删改查的操作指南(python)

查询数据

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

pyMySQL实现增删改查的操作指南(python)

删除表中的记录

代码如下:


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

pyMySQL实现增删改查的操作指南(python)

事务操作

提交事务: connection.commit()

回滚事务: connection.rollback()

总结

到此这篇关于pymsql实现增删改查(python)的文章就介绍到这了,更多相关pymsql增删改查内容请搜索四海网以前的文章或继续浏览下面的相关文章希望大家以后多多支持四海网!

本文来自:http://www.q1010.com/181/18797-0.html

注:关于Python之pyMySQL实现增删改查的操作指南的内容就先介绍到这里,更多相关文章的可以留意四海网的其他信息。

关键词:python

您可能感兴趣的文章

  • Python之Pandas直接核算Excel中的快递费用的实现方法
  • Python之pytorch 中autograd.grad()函数的简单示例
  • Python之开发一款操作MySQL的小工具
  • python3调用c语言代码的全过程记录
  • Python实现subprocess执行外部命令的简单示例
  • Python执行外部命令subprocess的使用分析
  • Python之Pytest测试用例的执行方法的简单示例
  • 解决python列表list中的截取问题
  • Python之pycharm查看某一函数源码的快捷键的简单示例
  • Python之Parser的用法
上一篇:Python之仿真双径效应的实现方法
下一篇:解决python列表list中的截取问题
热门文章
  • Python 处理Cookie的菜鸟教程(一)Cookie库
  • python之pandas取dataframe特定行列的简单示例
  • Python解决json.dumps错误::‘utf8’ codec can‘t decode byte
  • Python通过pythony连接Hive执行Hql的脚本
  • Python 三种方法删除列表中重复元素的简单示例
  • python爬虫代码示例
  • Python 中英文标点转换示例
  • Python 不得不知的开源项目解析
  • Python urlencode编码和url拼接实现方法
  • python按中文拆分中英文混合字符串的简单示例
  • 最新文章
    • Python利用numpy三层神经网络的简单示例
    • pygame可视化幸运大转盘的简单示例
    • Python爬虫之爬取二手房信息的简单示例
    • Python之time库的简单示例
    • OpenCV灰度、高斯模糊、边缘检测的简单示例
    • Python安装Bs4及使用的简单示例
    • django自定义manage.py管理命令的简单示例
    • Python之matplotlib 向任意位置添加一个子图(axes)的简单示例
    • Python图像标签标注软件labelme分析的简单示例
    • python调用摄像头并拍照发邮箱的简单示例

四海网收集整理一些常用的php代码,JS代码,数据库mysql等技术文章。