一、环境

Windows  7 x64     python 3.7.1    pymysql 0.9.3  mysql5.6.43


二、pymysql的简单使用

1、准备数据库demo_temp

create database demo_temp;

2、连接数据库

import pymysql.cursors
connect = pymysql.connect(
host='127.0.0.1',
user='root',
password='',
db='demo_temp',
charset='utf8',
cursorclass=pymysql.cursors.DictCursor
)

3、创建表

import pymysql.cursors
# 连接数据库
connect = pymysql.connect(
host='127.0.0.1',
user='root',
password='',
db='demo_temp',
charset='utf8',
cursorclass=pymysql.cursors.DictCursor
)
# 创建表users
with connect.cursor() as cursor:
sql = """
CREATE TABLE users (
id INT PRIMARY KEY AUTO_INCREMENT ,
user CHAR(30),
passwd CHAR(20))
"""
cursor.execute(sql)
connect.close()

4、一个简单的增、删、改、查实例

import pymysql.cursors
# 连接数据库
connect = pymysql.connect(
host='127.0.0.1',
user='root',
password='',
db='demo_temp',
charset='utf8',
cursorclass=pymysql.cursors.DictCursor
) with connect.cursor() as cursor: # 创建游标
# 创建表
sql = """
CREATE TABLE users (
id INT PRIMARY KEY AUTO_INCREMENT ,
user CHAR(30),
passwd CHAR(20))
"""
cursor.execute(sql)
# 向表中插入数据
sql = """
INSERT INTO users (user,passwd) VALUES ('小明','123')
"""
cursor.execute(sql)
connect.commit() # 插入数据后必须更新 # 查询数据
sql = """
select * from users
"""
cursor.execute(sql)
ret = cursor.fetchone() # 提取查询数据
print(ret)
# 修改数据
sql = """
update users set user='葫芦娃' where id=1
"""
cursor.execute(sql) # 再次查询数据
sql = """
select * from users
"""
cursor.execute(sql)
ret = cursor.fetchone() # 提取查询数据
print(ret) connect.close() # 关闭数据库连接 # 打印内容如下
{'id': 1, 'user': '小明', 'passwd': ''}
{'id': 1, 'user': '葫芦娃', 'passwd': ''}

5、简单的事务

import pymysql.cursors

# 连接数据库
connect = pymysql.connect(
host='127.0.0.1',
user='root',
password='',
db='demo_temp',
charset='utf8',
cursorclass=pymysql.cursors.DictCursor
) try:
with connect.cursor() as cursor: # 创建游标
# 插入数据
sql = """
INSERT INTO users (user,passwd) VALUES ('11111','123')
"""
cursor.execute(sql)
# 更新数据
sql_1 = """
update users set user='葫芦娃' where id=1
"""
cursor.execute(sql_1)
raise NameError # 更新数据时主动抛出异常 except Exception as e:
connect.rollback() # 事务回滚
connect.commit() connect.close() # 关闭数据库连接

通过下面的小动画我们可以看出,这里模拟在更新数据时出现问题。而插入数据时没有问题的。然后执行事务回滚,最终数据没有被写入到数据库中。


三、Connection中常用API

1、open() :检测数据库是否连接。

connect.open:如果数据库连接返回Trhe,否则返回False。

2、ping(reconnect=True)

connect.ping(reconnect=True):如果reconnect=True表示连接断开后,重新进行连接。

import pymysql.cursors

# 连接数据库
connect = pymysql.connect(
host='127.0.0.1',
user='root',
password='',
db='demo_temp',
charset='utf8',
cursorclass=pymysql.cursors.DictCursor
)
print(connect.open) # 打印数据库连接状态
connect.close() # 关闭数据库连接
connect.ping(reconnect=True) # 重新连接数据库
print(connect.open) # 打印数据库连接状态

下面的小动画向我们展示了当connect断开连接后,使用connect.ping(reconnect=True)又重新连接到了数据库。

3、rollback():回滚当前事务,用法在上面,这里就不再演示了。

4、select_db(db):切换数据库。

# demo_test数据库中users表数据
mysql> select * from users;
+----+-----------+--------+
| id | user | passwd |
+----+-----------+--------+
| 1 | 小明 | 123 |
| 2 | 小刚 | 123 |
| 3 | 小红 | 123 |
| 4 | 葫芦娃 | 123 |
| 5 | 小明 | 123 |
+----+-----------+--------+ # demo_temp2库中test表中数据
mysql> select * from test;
+------+------+----------+
| id | user | password |
+------+------+----------+
| 1 | abc | 123 |
+------+------+----------+ import pymysql.cursors # 连接数据库
connect = pymysql.connect(
host='127.0.0.1',
user='root',
password='',
db='demo_temp',
charset='utf8',
cursorclass=pymysql.cursors.DictCursor
)
with connect.cursor() as cursor: # 创建游标 # 查询demo_temp中users表的数据
sql = """
select * from users
"""
cursor.execute(sql)
ret = cursor.fetchall() # 提取查询数据
print(ret)
print('-'*80)
# 切换到demo_temp2数据库,查询test表的数据
connect.select_db('demo_temp2')
sql = """
select * from test
"""
cursor.execute(sql)
ret = cursor.fetchall() # 提取查询数据
print(ret) connect.close() # 关闭数据库连接 # 打印结果
[{'id': 1, 'user': '小明', 'passwd': ''}, {'id': 2, 'user': '小刚', 'passwd': ''}, {'id': 3, 'user': '小红', 'passwd': ''},
{'id': 4, 'user': '葫芦娃', 'passwd': ''}, {'id': 5, 'user': '小明', 'passwd': ''}]
--------------------------------------------------------------------------------
[{'id': 1, 'user': 'abc', 'password': ''}]

5、cursor():创建游标对象,用于操作数据(增、删、改、查)。

6、commit():提交请求,当向数据库中插入数据时,需要使用commit()进行提交,否则数据将不能写入数据库。

7、close():关闭数据库连接。


四、Cursor常用API

1、cursor.execute(query, args=None):执行sql语句。

参数:

  • query (str):sql语句.
  • args (tuple, list or dict):sql语句中如果有变量,或者格式化输出,会在这里填充数据。

Returns:返回一个int值,表示sql语句影响到的行数。

下面演示插入数据的四种方式:

import pymysql.cursors

# 连接数据库
connect = pymysql.connect(
host='127.0.0.1',
user='root',
password='',
db='demo_temp',
charset='utf8',
cursorclass=pymysql.cursors.DictCursor
)
with connect.cursor() as cursor: # 创建游标 # 第一种方式向表中插入数据
sql = """
INSERT INTO users (user,passwd) VALUES ('123','123')
"""
cursor.execute(sql) # 第二种方式向表中插入数据
sql = """
INSERT INTO users (user,passwd) VALUES (%s,%s)
"""
cursor.execute(sql,['','']) # 第三种方式向表中插入数据
sql = """
INSERT INTO users (user,passwd) VALUES (%s,%s)
"""
cursor.execute(sql, ('', '')) # 第四种方式向表中插入数据
sql = """
INSERT INTO users (user,passwd) VALUES (%(a)s,%(b)s)
"""
cursor.execute(sql, {'a':'abc','b':''}) # 这里的'a'和'b'要和上面VALUES中对应
connect.commit() # 插入数据后必须更新
# 查询数据
sql = """
select * from users
"""
cursor.execute(sql)
ret = cursor.fetchall() # 提取查询数据
print(ret) connect.close() # 关闭数据库连接

2、cursor.executemany(query, args):可以执行多条sql语句。
参数:    
query :sql语句
args:可迭代对象
Returns:返回sql语句影响到的行数。

下面是方法实例:

import pymysql.cursors

# 连接数据库
connect = pymysql.connect(
host='127.0.0.1',
user='root',
password='',
db='demo_temp',
charset='utf8',
cursorclass=pymysql.cursors.DictCursor
)
with connect.cursor() as cursor: # 创建游标 # 插入多条数据
sql = """
INSERT INTO users (user,passwd) VALUES (%s,%s)
"""
ret_row = cursor.executemany(sql,[['a',''],['b',''],['c','']]) # 在args中传入一个可迭代对象。
connect.commit() # 插入数据后必须更新
print(f'当前受影响了{ret_row}行') # 查询数据
sql = """
select * from users
"""
cursor.execute(sql)
ret = cursor.fetchall() # 提取查询数据
print(ret) connect.close() # 关闭数据库连接

3、cursor.fetchone():从查询语句中获取一条查询结果。

4、cursor.fetchall():获取所有查询到的结果。

5、cursor.fetchmany(size):根据size获取相应的行数。

6、cursor.mogrify(query, args=None):返回执行的sql语句,下面是示例:

import pymysql.cursors

# 连接数据库
connect = pymysql.connect(
host='127.0.0.1',
user='root',
password='',
db='demo_temp',
charset='utf8',
cursorclass=pymysql.cursors.DictCursor
)
with connect.cursor() as cursor: # 创建游标
sql = """
select * from users
"""
cursor.execute(sql)
ret_sql = cursor.mogrify(sql) # 返回执行的sql语句
cursor.fetchmany(2) # 提取查询数据
print(ret_sql) connect.close() # 关闭数据库连接

7、cursor.close():关闭游标,关闭游标后,游标内所有数据将被清空。

参考文档:https://pymysql.readthedocs.io/en/latest/

pymysql 的简单使用的更多相关文章

  1. 对pymysql的简单封装

    #coding=utf-8 #!/usr/bin/python import pymysql class MYSQL: """ 对pymysql的简单封装 "& ...

  2. pymysql DAO简单封装

    #!/usr/bin/env python # -*-coding:utf-8 -*- # # 无法执行多个query,self.conn.close()放在CdbConn类的单独函数中,每次quer ...

  3. pymysql 模块简单使用

    目录 pymysql 模块简单使用 安装 pymysql 模块 使用 pymysql 连接数据库 并插入数据 使用pymysql 插入数据 修改查询显示结果 pymysql 模块简单使用 安装 pym ...

  4. python之pymysql模块简单应用

    众所周知,想要在python程序中执行SQL语句需要使用第三方模块:pymysql. 下面,我将为大家简述一下pymysql第三方库的安装到使用的大体流程. pymysql的安装 1.windows系 ...

  5. python_way day12 RabbitMQ ,pymysql

    python_way day12 1.RabbitMQ 2.pymysql RabbitMQ 1.基本用法 """ producer """ ...

  6. navicat 和 pymysql

    ---------------------------------------------------相信时间的力量,单每月经过努力的时间,一切的安排都是懊脑的安排. # # ------------ ...

  7. python框架---->pymysql的使用

    这里面学习一下python中操作mysql的第三方库pymysql的使用.很多我们以为一辈子都不会忘掉的事情,就在我们念念不忘的日子里.被我们遗忘了. pymysql的简单使用 我们创建一张表来进行下 ...

  8. python3与mysql交互:pymysql

    python3与mysql交互 1.安装pymysql模块 pip3 install pymysql3 2.pymysql的简单使用: # /usr/bin/env python3 import py ...

  9. python3与mysql交互

    1.安装pymysql模块 pip3 install pymysql3 2.pymysql的简单使用: # /usr/bin/env python3 import pymysql class Mysq ...

随机推荐

  1. 并发—JVM内部机制和外部机制处理方法

    并发常见的编程场景,一句话概括就是,需要协调多个线程之间的协作,已保证程序按照自己原本的意愿执行.那么究竟应该如何协调多个线程? 这个问题比较宽泛,一般情况下,我们按照方式的纬度去简单区分,有以下两种 ...

  2. 滑动门出现的背景---实例微信导航栏(a盒子里面包span盒子,文字写在span里)

    需求: 制作网页时,为了美观,常常需要为网页元素设置特殊形状的背景,比如微信导航栏,有凸起和凹下去的感觉,其中最大的问题是字数不同,如何做? 解决: 用一个a包含span来制作,字数放在span里面. ...

  3. 基于vue+uniapp直播项目|uni-app仿抖音/陌陌直播室

    一.项目简介 uni-liveShow是一个基于vue+uni-app技术开发的集小视频/IM聊天/直播等功能于一体的微直播项目.界面仿制抖音|火山小视频/陌陌直播,支持编译到多端(H5.小程序.Ap ...

  4. Incorrect datetime value: '' for column 'examDate' at row 1

    出问题的程序:user.setCreateTime(new Date()); 控制台图片一张,问题是:Incorrect datetime value: '' for column 'createTi ...

  5. fiddler---Fiddler查看get和post请求

    前几篇写了Fiddler的一些功能介绍,今天我们一起学习下如何通过fiddler查看get请求和post请求和get,post区别 get请求 1.启动fiddler,抓取安静博客地址 2.通过fid ...

  6. 初学JavaScript正则表达式(二)

    正则表达式的实例化与标识符 字面量: var reg = /\bis\b/g // \b--字符边界 g全文搜索 查找单词为is的字符 He is a boy. IS He? 构造函数: var re ...

  7. luoguP3258 [JLOI2014]松鼠的新家

    树上差分 树上差分分析 使点x到点y的路径上(链上),全加上一个值,可以选择使用树上差分(不用线段树乱搞.... 首先,和普通的差分一样,要有一个tag.然而,对于一个结点,我们需要求出它全部儿子的t ...

  8. 人工智能+Python:十大Markdown语法简明教程

    Markdown 是一种轻量级的标记语言,用户可以使用诸如 * # 等简单的标记符号以最小的输入代价生成极富表现力的文档,目前也被越来越多的写作爱好者,撰稿者广泛使用.本文希望用直观的方法来讲述Mar ...

  9. QTP10启动错误:Error creatingUnable to create configuration directory "C:UsersmR?ã? directory entry

    安装完之后打开就一直: 百度也不知道为哈子(莫非是中文的用户名?反正我不想重装系统),真是很气人. 我就直接创建了一个临时账户,登陆进去,就可以运行了:

  10. MySQL 行溢出数据

    MySQL 行溢出数据 MySQL 对一条记录占用的最大储存空间是有限制的,除了 BLOB 和 TEXT 类型之外,其他所有列 (不包括隐藏列和记录头信息) 占用的字节长度不能超过 65535 个字节 ...