pymsql操作mysql的方式

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介:

python操作mysql的方式都是通过模块的形式:
原生的:pymsql
ORM框架 SQLAchemy

pymysql模块

pymsql 是python中的mysql模块,要想使用这个模块,就需要先安装,安装步骤如下:

pip3 install pymysql
或者
easy_install pymysql

pymysql的使用

使用步骤:
1、导入模块
2、创建连接
3、创建拿去数据的游标(手)
4、执行sql,并返回受影响的行数
5、关闭游标(拿回手)
6、关闭连接
代码如下:

#导入模块
import pymysql
#创建连接
conn = pymysql.connect(host='localhost',port=3306,user='kk',passwd='123',db='pysqltest')
#创建游标
course = conn.cursor()
#执行sql
插入表
row1 = course.execute("create table t1(id int auto_increment PRIMARY KEY ,name VARCHAR (32) not NULL )")
插入多天数据用executemany这个函数,后面用列表
# row2 = course.executemany("insert into t1 (name) VALUES (%s)",[("kk"),("gg")])
更新表,这个会把name一列全部修改为www
# row3 = course.execute("update t1 set name='www'")
条件修改,只把后面的id=1的修改
row4 = course.execute("update t1 set name='ee' WHERE id = %s",1)

#提交到数据库
conn.commit()
#关闭游标
course.close()
#关闭数据库连接
conn.close()

结果:
pymsql操作mysql的方式

获取自己增ID

这个就是数据库表里面的auto_increment的最后一个值,我们在数据库中可以通过alter 表名+set auto_increment_increment=xx来设置,这里我们通过pymysql怎么获取这个值那?

# 获取最新自增ID,把这个写到py文件里面,就可以获得当前操作后得到的id值
new_id = cursor.lastrowid

获取数据

pymysql是通过游标来拿去数据,可以一条一条的拿 也可以一次全部都拿回来

import pymysql

conn = pymysql.connect(host='127.0.0.1', port=3306, user='root', passwd='123', db='t1')
cursor = conn.cursor()
cursor.execute("select * from hosts")
# 获取第一行数据
row_1 = cursor.fetchone()

# 获取前n行数据
# row_2 = cursor.fetchmany(3)
# 获取所有数据
# row_3 = cursor.fetchall() 
conn.commit()
cursor.close()
conn.close()

在fetch数据时按照顺序进行,可以使用cursor.scroll(num,mode)来移动游标位置,如:
cursor.scroll(1,mode='relative') # 相对当前位置移动
cursor.scroll(2,mode='absolute') # 相对绝对位置移动


fetch默认得到的值是元祖的数据,要想得到字典的数据,要在建立游标的时候指定:
cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)



本文转自 kesungang 51CTO博客,原文链接:http://blog.51cto.com/sgk2011/2052364,如需转载请自行联系原作者

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
1月前
|
SQL 关系型数据库 MySQL
Python怎么操作Mysql数据库
Python怎么操作Mysql数据库
49 0
|
1月前
|
SQL 关系型数据库 MySQL
python如何操作mysql数据库
python如何操作mysql数据库
24 0
|
2月前
|
SQL 存储 算法
mysql常用指令操作
mysql常用指令操作
|
15天前
|
存储 SQL 关系型数据库
【MySQL】4. 表的操作
【MySQL】4. 表的操作
19 0
|
3月前
|
关系型数据库 MySQL
MySQL对小数进行四舍五入等操作
MySQL对小数进行四舍五入等操作
25 0
|
3月前
|
SQL 关系型数据库 MySQL
MySQL| 数据库的管理和操作【操作数据库和操作表】【附练习】
MySQL | 数据库的基本操作和表的基本操作【附练习】
|
29天前
|
SQL 关系型数据库 MySQL
|
3月前
|
SQL 关系型数据库 MySQL
MySQL | 数据库的管理和操作【表的增删改查】(一)
MySQL | 数据库的管理和操作【表的增删改查】
|
3月前
|
SQL 关系型数据库 MySQL
MySQL | 数据库的管理和操作【表的增删改查】(二)
MySQL | 数据库的管理和操作【表的增删改查】(二)
|
14天前
|
缓存 关系型数据库 MySQL
MySQL查询优化:提速查询效率的13大秘籍(合理使用索引合并、优化配置参数、使用分区优化性能、避免不必要的排序和group by操作)(下)
MySQL查询优化:提速查询效率的13大秘籍(合理使用索引合并、优化配置参数、使用分区优化性能、避免不必要的排序和group by操作)(下)

推荐镜像

更多