PyMySQL 是在 Python3.x 版本中用于连接 MySQL 服务器的一个库,Python2中则使用mysqldb。

安装:

pip3 install PyMySQL

常用参数:

pymysql.Connect()   参数说明

host(str)     mysql服务器地址

port(int)     端口

user(str)    用户名

passwd(str)   密码

db(str)    数据库名称

charset(str)    链接编码

connection() 对象支持的方法

cursor()    使用该链接创建并返回游标

commit()    提交当前事务

rollback()    回滚当前事务

close()    关闭链接

curser()对象支持的方法

execute(op)     执行一个数据库的查询命令

fetchone()    取得结果集的下一行

fetchmany(size)    获取结果集的下几行

fetchall()   获取结果集中的所有行

rowcount()   返回数据条数或影响行数

close()   关闭游标对象

lastrowid 获取自增ID


  连接数据库;

import pymysql

connect = pymysql.Connect(
host = 'localhost',
port = ,
user = 'root',
passwd = '',
db = 'python',
charset = 'utf8',
cursorclass = pymysql.cursors.DictCursor // 指定类型
) //获取游标
cursor = connect.cursor()

  插入数据:

sql = "INSERT INTO trade (name, account, saving) VALUES ( '%s', '%s', %.2f )"
data = ('雷军', '', )
cursor.execute(sql % data)
connect.commit()
print('成功插入', cursor.rowcount, '条数据') // 获取插入的ID(一定要在commit之前获取)
last_id = curs.lastrowid

  修改数据:

sql = "UPDATE trade SET saving = %.2f WHERE account = '%s' "
data = (, '')
cursor.execute(sql % data)
connect.commit()
print('成功修改', cursor.rowcount, '条数据')

  查询数据:

sql = "SELECT name,saving FROM trade WHERE account = '%s' "
data = ('',)
cursor.execute(sql % data)
for row in cursor.fetchall():
print("Name:%s\tSaving:%.2f" % row)
print('共查找出', cursor.rowcount, '条数据') # 返回结果是一个字典类型数据

  删除数据:

sql = "DELETE FROM trade WHERE account = '%s' LIMIT %d"
data = ('', )
cursor.execute(sql % data)
connect.commit()
print('成功删除', cursor.rowcount, '条数据')

  事务处理:

sql_1 = "UPDATE trade SET saving = saving + 1000 WHERE account = '18012345678' "
sql_2 = "UPDATE trade SET expend = expend + 1000 WHERE account = '18012345678' "
sql_3 = "UPDATE trade SET income = income + 2000 WHERE account = '18012345678' " try:
cursor.execute(sql_1) # 储蓄增加1000
cursor.execute(sql_2) # 支出增加1000
cursor.execute(sql_3) # 收入增加2000
except Exception as e:
connect.rollback() # 事务回滚
print('事务处理失败', e)
else:
connect.commit() # 事务提交
print('事务处理成功', cursor.rowcount) # 关闭连接
cursor.close()
connect.close()

  

游标控制

所有的数据查询操作均基于游标,我们可以通过cursor.scroll(num, mode)控制游标的位置。

cursor.scroll(, mode='relative') # 相对当前位置移动
cursor.scroll(, mode='absolute') # 相对绝对位置移动

设置游标类型

查询时,默认返回的数据类型为元组,可以自定义设置返回类型。支持5种游标类型:

  • Cursor: 默认,元组类型
  • DictCursor: 字典类型
  • DictCursorMixin: 支持自定义的游标类型,需先自定义才可使用
  • SSCursor: 无缓冲元组类型
  • SSDictCursor: 无缓冲字典类型

无缓冲游标类型,适用于数据量很大,一次性返回太慢,或者服务端带宽较小时。

事务处理

  • 开启事务 connection.begin()

  • 提交修改 connection.commit()

  • 回滚事务 connection.rollback()

防 SQL 注入

转义特殊字符 connection.escape_string(str)

参数化语句 支持传入参数进行自动转义、格式化 SQL 语句,以避免 SQL 注入等安全问题。

# 插入数据(元组或列表)
effect_row = cursor.execute('INSERT INTO `users` (`name`, `age`) VALUES (%s, %s)', ('mary', )) # 插入数据(字典)
info = {'name': 'fake', 'age': }
effect_row = cursor.execute('INSERT INTO `users` (`name`, `age`) VALUES (%(name)s, %(age)s)', info) # 批量插入
effect_row = cursor.executemany(
'INSERT INTO `users` (`name`, `age`) VALUES (%s, %s) ON DUPLICATE KEY UPDATE age=VALUES(age)', [
('hello', ),
('fake', ),
])

示例:

  1. 执行SQL

cursor = connection.cursor()

# 创建数据表
effect_row = cursor.execute('''
CREATE TABLE `users` (
`name` varchar() NOT NULL,
`age` int() unsigned NOT NULL DEFAULT '',
PRIMARY KEY (`name`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8
''') # 插入数据(元组或列表)
effect_row = cursor.execute('INSERT INTO `users` (`name`, `age`) VALUES (%s, %s)', ('mary', )) # 插入数据(字典)
info = {'name': 'fake', 'age': }
effect_row = cursor.execute('INSERT INTO `users` (`name`, `age`) VALUES (%(name)s, %(age)s)', info) connection.commit()

  

# 获取游标
cursor = connection.cursor() # 批量插入
effect_row = cursor.executemany(
'INSERT INTO `users` (`name`, `age`) VALUES (%s, %s) ON DUPLICATE KEY UPDATE age=VALUES(age)', [
('hello', ),
('fake', ),
]) connection.commit()

  注意: INSERT,UPDATE,DELETE等修改操作,需要手动执行commit()完成对数据的修改提交

  2.查询数据

# 执行查询 SQL
cursor.execute('SELECT * FROM `users`') # 获取单条数据
cursor.fetchone() # 获取前N条数据
cursor.fetchmany() # 获取所有数据
cursor.fetchall()

 常见问题:

  1.

pymysql.err.ProgrammingError: (, 'You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near \'fas好",\'wozhidaole知道了\'" where title = "好"\' at line 1')

  字符串中出现引号,导致SQL语句发生错误,需要进行转义

pymysql.escape_string(str)

    

最新文章

  1. Mac下安装ionic和cordova,并生成iOS项目
  2. nodejs net模块
  3. R语言将字符串矩阵转化为数值型矩阵
  4. JQ 全选设定与设置选中
  5. Redis整合Spring结合使用缓存实例(三)
  6. python eval
  7. TCP/IP笔记 应用层(1)——DNS
  8. vector 汇总
  9. Gimp制作圆角透明图片
  10. 玩转Web之Jsp(一)-----jsp中的静态包含(<%@include file="url"%>)与动态包含(<jsp:include>)
  11. jQuery -> 获取各种滤芯(filter)
  12. USB LPT 端口映射
  13. PhpStorm 10.0注册
  14. Codeforces Round #404 (Div. 2) D. Anton and School - 2
  15. React Native 填坑之神奇的报错,已解决
  16. gridview 选中某行后 某行的按钮显示,无选中则隐藏
  17. ****** 四十二 ******、软设笔记【网络基础】-IPv6协议、常用的网络协议
  18. spring-data-redis和jedis版本对应问题
  19. pandas3
  20. Navicat 连接 Mysql8.0 出现2059问题的解决方法

热门文章

  1. C#获取实体类属性名和值
  2. SVN 撤回(回滚)提交的代码
  3. spring 过滤器- 过滤登陆请求路径(过滤静态资源跳转到登陆页面)
  4. Elasticsearch mapping映射文件设置没有生效
  5. linux常用命令(20)用SecureCRT来上传和下载文件
  6. /usr/lib/libstdc++.so.6: version `GLIBCXX_3.4.15' not found错误的解决 转载
  7. Python爬虫学习==>第十一章:分析Ajax请求-抓取今日头条信息
  8. PHP curl出现SSL certificate problem: self signed certificate in certificate chain
  9. 【linux杂谈】遇到REMOTE HOST IDENTIFICATION HAS CHANGED怎么办?
  10. 蓝鲸-监控 排错思路 - 原理push - bkdata报错 - saas的日志