iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >pymysql实现增删改查的操作指南(python)
  • 716
分享到

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

pymysql增删改查python增删改查pythonpymysql用法 2022-06-02 22:06:16 716人浏览 安东尼
摘要

安装pyMysql:pip install pymysql (在命令行窗口中执行) 卸载pymysql:pip uninstall pymysql (在命令行窗口中执行) 数据库的连接 需要注意的是port是不用引

安装pyMysql:pip install pymysql (在命令行窗口中执行)

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

向数据库中添加数据

需要注意的是规范sql,该写的字段都写上,不使用默认对应

提交事务的对象是数据库连接对象,而不是游标对象

PyCharm连接mysql数据时,如果连接驱动是高版本,需要加上时区,jdbc:mysql://localhost/book?serverTimezone=GMT%2B8

如果主键是自动递增,则不能手动指定值,不能写该字段,让其自增长


# 获取数据库连接对象
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()


修改表中的数据

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

卸载第三方库: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()

查询数据

项目中的.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()

总结

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

您可能感兴趣的文档:

--结束END--

本文标题: pymysql实现增删改查的操作指南(python)

本文链接: https://www.lsjlt.com/news/10628.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • sql中外码怎么设置
    sql 中外码设置步骤:确定父表和子表。在子表中创建外码列,引用父表主键。使用 foreign key 约束将外码列链接到父表主键。指定引用动作,以处理父表数据更改时的子表数据操作。 ...
    99+
    2024-05-15
  • sql中having是什么
    having 子句用于过滤分组结果,应用于分组后的数据集。它与 where 子句类似,但基于分组结果而不是原始数据。用法:1. 过滤分组后的聚合值。2. 根据分组后的...
    99+
    2024-05-15
  • 在sql中空值用什么表示
    在 sql 中,空值表示未知或不存在的值,可使用 null、空字符串或特殊值表示。处理空值的方法包括使用操作符(is null/is not null)、coalesce 函数(返回第一...
    99+
    2024-05-15
    oracle
  • sql中number什么意思
    sql 中的 number 类型用于存储数值数据,包括小数和整数,特别适合货币、度量和科学数据。其精度由 scale(小数点位数)和 precision(整数字段和小数字段总位数)决定。...
    99+
    2024-05-15
  • sql中空值赋值为0怎么写
    可以通过使用 coalesce() 函数将 sql 中的空值替换为指定值(如 0)。coalesce() 的语法为 coalesce(expression, replacement),其...
    99+
    2024-05-15
  • sql中revoke语句的功能
    revoke 语句用于撤销指定用户或角色的权限或角色成员资格。可撤销的权限包括 select、insert、update、delete 等,撤销的对象类型包括表、视图、存储过程...
    99+
    2024-05-15
    敏感数据
  • sql中REVOKE是什么意思
    revoke 是 sql 中用于撤销用户或角色对数据库对象权限的命令。它通过撤销权限类型、对象级别和目标权限来实现:权限类型:撤销 select、insert、update、d...
    99+
    2024-05-15
  • sql中sp是什么意思
    sql中的sp是存储过程的缩写,它是一种预编译的、已命名的sql语句块,存储在数据库中,可以被用户通过简单命令调用。存储过程的特点有:可重用性、模块化、性能优化、安全性、事务支持。存储过...
    99+
    2024-05-15
    敏感数据
  • sql中references是什么意思
    sql 中的 references 关键字用于在外键约束中定义表之间的父-子关系。外键约束确保子表中的行都引用父表中存在的行,从而维护数据完整性。references 语法的格式为:fo...
    99+
    2024-05-15
  • sql中判断字段为空怎么写
    sql 中可通过 4 种方法判断字段是否为空:1)is null 运算符;2)is not null 运算符;3)coalesce() 函数;4)case 语句。例如,查询所有 colu...
    99+
    2024-05-15
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作