Python使用pymysql三方库操作 mysql数据库

为什么要使用pymysql

在使用Python工作与学习中难免会使用到mysql数据库,使用pymysql三方库可以让我们轻松的对数据库的记录进行操作,如创建、修改,删除表,如增加、删除、修改、查询数据表中的记录,下边记录一下pymysql的使用方法:


连接方法 Connect = connect = Connection

python 复制代码
# 创建mysql数据库连接
conn = Connection(
    user='root',
    host='192.168.109.135',
    password='test_12345',
    port=3306,
    database='test_db',
    charset='utf8',
    cursorclass=cursors.DictCursor
)

CURSOR种类

cursor 的种类有四种,默认使用的是Cursor,还有DictCursor,SSCursor,SSDictCursor,Cursor 返回的结果是以元组的形式返回的,DictCursor,是以字典的形式返回的。DictCursor是继承了Cursor与DictCursorMixin,DictCursorMixin里面只有函数两个方法。(可以选择自己需要的返回形式)

INSERT INTO语句(增)

单条数据插入

python 复制代码
 data = (1, 'group1', 'group1/M00/00/00/wKhthmT1PGuAXV09AAABFcYZOGg5350.py', 'Upload successed.', 'fdfs.py', '277B', '192.168.109.134', 'fdfs.py')
 with conn.cursor() as cursor:
        # Create a new record
        sql = "INSERT INTO `upload_file` (`Group name`, `Remote file_id`, `Status`, `Local file name`, `Uploaded size`, `Storage IP`, `Filename`)" \
              " VALUES (%s, %s, %s, %s, %s, %s, %s)"
        cursor.execute(sql, data)
        conn.commit()

多条数据插入

python 复制代码
 data = ((1, 'group1', 'group1/M00/00/00/wKhthmT1PGuAXV09AAABFcYZOGg5350.py', 'Upload successed.', 'fdfs.py', '277B', '192.168.109.134', 'fdfs.py'), (2, 'group1', 'group1/M00/00/00/wKhthmT1TMKAH20TAAAD-MJMli03267.py', 'Upload successed.', 'fdfs.py', '1016B', '192.168.109.134', 'fdfs.py'), (3, 'group1', 'group1/M00/00/00/wKhthmT1TSqAFhCyAAxZcPR00vw.tar.gz', 'Upload successed.', 'fastdfs-6.06.tar.gz', '790.36KB', '192.168.109.134', 'fastdfs-6.06.tar.gz'), (4, 'group1', 'group1/M00/00/00/wKhthmT1TTCABEUgAABN8HAGbcY.tar.gz', 'Upload successed.', 'fastdfs-nginx-module-1.22.tar.gz', '19.48KB', '192.168.109.134', 'fastdfs-nginx-module-1.22.tar.gz'), (5, 'group1', 'group1/M00/00/00/wKhthmT1TTWAU-W3ABBjHPqFuIs.tar.gz', 'Upload successed.', 'nginx-1.22.1.tar.gz', '1.02MB', '192.168.109.134', 'nginx-1.22.1.tar.gz'), (6, 'group1', 'group1/M00/00/00/wKhthmT1TUCAaierAAKKfr3HBzE.tar.gz', 'Upload successed.', 'libfastcommon-1.0.43.tar.gz', '162.62KB', '192.168.109.134', 'libfastcommon-1.0.43.tar.gz'), (7, 'group1', 'group1/M00/00/00/wKhthmT1TVeANtONAAKKfr3HBzE.tar.gz', 'Upload successed.', '/tmp/libfastcommon-1.0.43.tar.gz', '162.62KB', '192.168.109.134', 'libfastcommon-1.0.43.tar.gz'))
 with conn.cursor() as cursor:
        # Create a new record
        sql = "INSERT INTO `upload_file` (`Group name`, `Remote file_id`, `Status`, `Local file name`, `Uploaded size`, `Storage IP`, `Filename`)" \
              " VALUES (%s, %s, %s, %s, %s, %s, %s)"
        cursor.executemany(sql, data)
        conn.commit()

DELETE 语句(删)

python 复制代码
def delete(pk: int):
    """
    delete from table where filed1='';
    :param pk:
    :return:
    """
    with conn.cursor() as cursor:
        # delete a record
        SQL = "delete from `upload_file` where id=%d" % pk
        cursor.execute(SQL)
        conn.commit()

UPDATE SET 语句(改)

python 复制代码
def update(pk):
    """update table set column1=value1, column2=value2"""
    with conn.cursor() as cursor:
        # delete a record
        SQL = "update upload_file set Filename='test.txt' where id=%d" % pk
        cursor.execute(SQL)
        conn.commit()

SELECT 语句(查)

多记录查询

python 复制代码
    def select(self, pk=None):
        with conn.cursor() as cursor:
            sql = """ SELECT * from `upload_file`"""
            cursor.execute(sql)
            rows = cursor.fetchall()
            print(rows)

单记录查询

python 复制代码
    def select(self, pk):
        with conn.cursor() as cursor:
            sql = """ SELECT * from `upload_file` where id=%d""" % pk
            cursor.execute(sql)
            rows = cursor.fetchone()
            print(rows)
相关推荐
爬山算法19 分钟前
Redis(69)Redis分布式锁的优点和缺点是什么?
数据库·redis·分布式
测试老哥20 分钟前
Postman环境变量设置全攻略
自动化测试·软件测试·python·测试工具·职场和发展·接口测试·postman
RestCloud23 分钟前
从数据库到价值:ETL 工具如何打通南大通用数据库与企业应用
数据库
惜月_treasure1 小时前
Text2SQL与工作流实现:让数据库查询变得轻松又高效
数据库·人工智能·python
-睡到自然醒~1 小时前
[go 面试] 并发与数据一致性:事务的保障
数据库·面试·golang
为乐ovo1 小时前
19.DCL-用户管理
数据库
可观测性用观测云1 小时前
阿里云 RDS MySQL 可观测性最佳实践
mysql
一个天蝎座 白勺 程序猿1 小时前
金仓数据库KingbaseES实现MongoDB平滑迁移全攻略:从架构适配到性能调优的完整实践
数据库·mongodb·数据迁移·kingbasees·金仓数据库
武子康1 小时前
Java-153 深入浅出 MongoDB 全面的适用场景分析与选型指南 场景应用指南
java·开发语言·数据库·mongodb·性能优化·系统架构·nosql
码猩2 小时前
获取dm音视频文案
python