网站首页 > 主流语言 > python 正文
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()
总结
到此这篇关于pymsql实现增删改查(python)的文章就介绍到这了,更多相关pymsql增删改查内容请搜索开源网以前的文章或继续浏览下面的相关文章希望大家以后多多支持开源网!
猜你喜欢
- 2021-07-16 Python数据分析入门之数据读取与存储
- 2021-07-16 python执行js代码的方法
- 2021-07-16 python使用Streamlit库制作Web可视化页面
- 2021-07-16 python制作的天气预报小工具(gui界面)
- 2021-07-16 python框架flask知识总结
- 2021-07-16 python 装饰器的使用与要点
- 2021-07-16 教你用python控制安卓手机
- 2021-07-16 Python绘制地图神器folium的新人入门指南
- 2021-07-16 基于python对B站收藏夹按照视频发布时间进行排序的问题
- 2021-07-12 python流水线框架pypeln的安装使用教程
你 发表评论:
欢迎- 2957℃JS彻底弄懂GMT和UTC时区
- 2830℃JS使用canvas技术模仿echarts柱状图
- 2650℃JS装饰者模式和TypeScript装饰器
- 2575℃JS ES6展开运算符的几个妙用
- 2544℃vue的ssr服务端渲染示例详解
- 2366℃jquery插件实现图片对比
- 2323℃微信小程序视频弹幕位置随机
- 1834℃docker安装redis设置密码并连接的操作
- 0℃未命名
- 开源分类
- 最近发表
-
- 云服务器推荐,云服务器去哪买靠谱?
- (1)python+selenium第一个自动化脚本:实现打开百度首页并搜索selenium
- Discuz!教程之启用HTTPS后解决各处遗留http://网址问题
- 网站如何识别 你是 selenium爬虫?那我们怎么解决(反反爬)
- 旋转拖动验证码解决方案
- python关键词排名_python实现百度关键词排名查询
- Unity3D研究院之通过ipa或apk获取游戏所使用的unity和Xcode版本
- Unity3D研究院编辑器之脚本生成Preset Libraries(十四)
- 手把手教你Charles抓包工具使用
- python开发的程序内存越来越大_遇到个python进程占用内存太多的问题 | 数据,更懂人心...
- 开源网标签
本文暂时没有评论,来添加一个吧(●'◡'●)