当前位置: 首页 > news >正文

DevOps系列之 Python操作数据库

pymysql操作mysql数据库

  • 安装pymysql

pip install pymysql

pymysql操作数据库

1.连接数据库 使用Connect方法连接数据库 pymysql.Connections.Connection(host=None, user=None, password='', database=None, port=0, charset='') 参数说明: host – 数据库服务器所在的主机。 user – 登录用户名。 password – 登录用户密码。 database – 连接的数据库。 port – 数据库开放的端口。(默认: 3306) charset – 连接字符集。 返回值: 返回连接对象

例子: link = pymysql.Connect(host='localhost', port=3306, user='root', password='123456', db='shop', charset='utf8')

方法说明
begin()开启事务
commit()提交事务
cursor(cursor=None)创建一个游标用来执行sql语句
rollback()回滚事务
close()关闭连接
select_db(db)选择数据库
  • 连接对象方法

2.创建游标

cursor = link.cursor() print(cursor.rowcount) #打印受影响行数

方法说明
close()关闭游标
execute(query, args=None)执行单条语句,传入需要执行的语句,是string类型;同时可以给查询传入参数,参数可以是tuple、list或dict。执行完成后,会返回执行语句的影响行数。
fetchone()取一条数据
fetchmany(n)取多条数据
fetchall()取所有数据

3.执行sql语句

# 执行sql语句

sql = 'select * from user1'

# 执行完sql语句,返回受影响的行数 num = cursor.execute(sql)

4.获取结果集 result1 = cursor.fetchone() print(result1)

5.关闭连接 cursor.close() link.close()

pymysql中事务处理

pymysql默认是没有开启自动提交事务,所以我们如果进行增、删、改,就必须手动提交或回滚事务。

sql = 'delete from user where id=%s' % user_id
​
# 如果要执行增删改语句的时候,下面的就是固定格式
try:cursor.execute(sql)# 如果全部执行成功,提交事务link.commit()print(cursor.lastrowid) #获取最后插入记录的自增id号
except Exception as e:print(e)link.rollback()
finally:cursor.close()link.close()

案例

使用pymysql向goods表中添加一条数据:

from pymysql import *​
def main():# 创建connection连接conn = connect(host='localhost', port=3306, database='shop', user='root',password='root', charset='utf8')# 获取cursor对象cs1 = conn.cursor()# 执行sql语句query = "insert into goods(id,name,price,num) values(%s,%s,%s,%s)"cs1.execute(query,(4,'蒙牛酸奶',13.9,88))# 提交之前的操作,如果之前已经执行多次的execute,那么就都进行提交conn.commit()# 关闭cursor对象cs1.close()# 关闭connection对象conn.close()if __name__ == '__main__':main()

当然也可以删除、查询、修改表中的数据,但是无论是怎么操作,都需要创建连接并在结束的时候关闭连接对象。

http://www.lryc.cn/news/278651.html

相关文章:

  • 【AI视野·今日NLP 自然语言处理论文速览 第七十四期】Wed, 10 Jan 2024
  • TDengine 签约积成电子
  • C++ 数组分页,经常有用到分页,索性做一个简单封装 已解决
  • Redis管道操作
  • 新一代通信协议 - Socket.D
  • 国产系统-银河麒麟桌面版安装wps
  • Day31 贪心算法 part01 理论基础 455.分发饼干 376.摆动序列 53.最大子序和
  • 行为型模式 | 观察者模式
  • Python面向对象之继承
  • 如何使用CFImagehost结合内网穿透搭建私人图床并无公网ip远程访问
  • Wargames与bash知识14
  • 2020年认证杯SPSSPRO杯数学建模C题(第二阶段)抗击疫情,我们能做什么全过程文档及程序
  • JAVA基础学习笔记-day17-反射
  • 经典算法-模拟退火算法的python实现
  • 谷粒学院项目redirect_uri 参数错误微信二维码登录
  • Jenkins+nexus
  • 「JavaSE」类和对象1
  • Ubuntu server搭建dhcp服务器
  • 2024--Django平台开发-Web框架和Django基础(二)---Mysql多版本共存(Mac系统)
  • Pytorch 反向传播 计算图被修改的报错
  • android studio设置gradle和gradle JDK版本
  • Android 15即将到来,或将推出5大新功能特性
  • sqlalchemy 事务自动控制(类java aop)
  • vue2-手写轮播图
  • Google I/O大会:Android 13
  • VUE指令(一)
  • 微信小程序开发学习笔记《7》全局配置以及小程序窗口
  • Vue、uniApp、微信小程序、Html5等实现数缓存
  • 如何将ArcGIS工程文件迁移到ArcGIS Pro内
  • Jenkins基础篇--添加用户和用户权限设置