python与MySQL
| 一、python与mysql交互 |
因版本不同python操作mysql有两个模块,python3不再支持MySQL-python,模块使用都一样:
python2.7:MySQL-python
python3:pymysql
安装:
pip install Mysql-python
pip install pymysql
pymysql介绍:
1.执行原生sql语句
#!/usr/bin/env python3
#_*_ coding:utf-8 _*_
#Author:wd
import pymysql
conn=pymysql.connect(host='10.0.0.241',port=3307,user='stu',passwd='1234qwer',db='student')#创建连接
cursor=conn.cursor()#创建游标
try:
#num=cursor.execute("create table student (name CHAR(20),age INT(3),date DAT )")#创建表不需要提交可以生效
num=cursor.execute("insert into student value('wd',22,'1993-05-22')")#执行sql返回受影响的条目数
print(num)
conn.commit() #pymysql默认开启了事务,进行数据库更新需要提交
except:
conn.rollback()#出现异常则回滚
cursor.close()#关闭游标
conn.close()#关闭连接
2.批量执行sql
实际是循环调用execute
def executemany(self, query, args):
# type: (str, list) -> int
#!/usr/bin/env python3
#_*_ coding:utf-8 _*_
#Author:wd
import pymysql
conn=pymysql.connect(host='10.0.0.241',port=3307,user='stu',passwd='1234qwer',db='student')#创建连接
cursor=conn.cursor()#创建游标
num=cursor.executemany("insert into student values(%s,%s,%s)",[('jack',22,'1993-01-11'),('tara',18,'1998-03-04')])
#一次性执行操作多条,参数为
print(num)#打印条结果条目
conn.commit() #pymysql默认开启了事务,进行数据库更新需要提交
new_id = cursor.lastrowid#如果是自增id,该方法可以获取到插入完成以后的ID
print(new_id)
cursor.close()#关闭游标
conn.close()#关闭连接
3.查询操作:fetch
#!/usr/bin/env python3
#_*_ coding:utf-8 _*_
#Author:wd import pymysql
conn=pymysql.connect(host='10.0.0.241',port=3307,user='stu',passwd='1234qwer',db='student')#创建连接
cursor=conn.cursor()#创建游标
cursor = conn.cursor()
cursor.execute("select * from student") # 获取第一行数据
row_1=cursor.fetchone()
print(row_1) # 获取前n行数据
row_2=cursor.fetchmany(3)
print(row_2)
# 获取所有数据
# row_3=cursor.fetchall()
cursor.scroll(0,mode='absolute')#将游标重新移至开始处
row_new=cursor.fetchone()
print(row_new)
cursor.close()#关闭游标
conn.close()#关闭连接
TIPS:使用fetchone获取数据如同读取文件一样,如果读一行游标会下移一行,
可以使用cursor.scroll(num,mode)来移动游标位置,如:
- cursor.scroll(1,mode='relative') # 相对当前位置移动
- cursor.scroll(2,mode='absolute') # 相对绝对位置移动
4.设置fetch获取数据类型
默认使用fetch查询结果是tuple,我们还可以设置获取的数据返回时dict
#!/usr/bin/env python3
#_*_ coding:utf-8 _*_
#Author:wd import pymysql conn = pymysql.connect(host='10.0.0.241', port=3307, user='stu', passwd='1234qwer', db='student')
# 游标设置为字典类型
cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)#设置游标类型为字典
r = cursor.execute("select * from student")
res = cursor.fetchone()
print(res)
cursor.close()
conn.close()
结果:
{'name': 'wd', 'age': 22, 'date': datetime.date(1993, 5, 22)}
python与MySQL的更多相关文章
- 【初学python】使用python连接mysql数据查询结果并显示
因为测试工作经常需要与后台数据库进行数据比较和统计,所以采用python编写连接数据库脚本方便测试,提高工作效率,脚本如下(python连接mysql需要引入第三方库MySQLdb,百度下载安装) # ...
- Python(九) Python 操作 MySQL 之 pysql 与 SQLAchemy
本文针对 Python 操作 MySQL 主要使用的两种方式讲解: 原生模块 pymsql ORM框架 SQLAchemy 本章内容: pymsql 执行 sql 增\删\改\查 语句 pymsql ...
- 使用 python 管理 mysql 开发工具箱 - 1
Mysql 是一个比较优秀的开源的数据库,很多公司都在使用.作为运维人员,经常做着一些重复性的工作,比如创建数据库实例,数据库备份等,完全都可以使用 python 编写一个工具来实现. 一.模块 Co ...
- 练习:python 操作Mysql 实现登录验证 用户权限管理
python 操作Mysql 实现登录验证 用户权限管理
- Python操作MySQL
本篇对于Python操作MySQL主要使用两种方式: 原生模块 pymsql ORM框架 SQLAchemy pymsql pymsql是Python中操作MySQL的模块,其使用方法和MySQLdb ...
- Python操作Mysql数据库时SQL语句的格式问题
一.概述 近日使用Python对Mysql数据库进行操作,遇到SQL语句死活出问题的情况.由于最初没有将异常打印出来,一直不知道原因.随后,将异常打印出来之后,通过异常信息,对代码进行修改.最终,成功 ...
- Python操作Mysql之基本操作
pymysql python操作mysql依赖pymysql这个模块 下载安装 pip3 install pymysql 操作mysql python操作mysql的时候,是通过”游标”来进行操作的. ...
- python对Mysql操作和使用ORM框架(SQLAlchemy)
python对mysql的操作 Mysql 常见操作 数据库操作 创建数据库 create database fuzjtest 删除数据库 drop database fuzjtest 查询数据库 s ...
- python操作mysql总结
Windows系统,python环境搭建. 下载并安装python2.7.11 https://www.python.org/downloads/ 下载并安装python的mysql包: http:/ ...
- python使用mysql数据库
一,安装mysql 如果是windows 用户,mysql 的安装非常简单,直接下载安装文件,双击安装文件一步一步进行操作即可. Linux 下的安装可能会更加简单,除了下载安装包进行安装外,一般的l ...
随机推荐
- JAVA类的创建: 创建JAVA的类 ,JAVA的字段,JAVA类的方法
1. 创建Java的类 如果说Java的一切都是对象,那么类型就是决定了某一类对象的外观与行为.可是类型的关键字不是type,而是class,创建一个新的类型要用下面的代码: 1 2 3 class ...
- 可视化编程开发板TurnipBit支持LED亮度可调功能
微软的makecode编辑器更新至版本v0.12.64.新增LED的可调亮度功能.而作为中文版可视化编程的口袋计算机TurnipBit完全兼容micro:bit,同样支持LED的亮度可调功能. 该项功 ...
- 解决ios微信页面回退不刷新的问题
在回退后需要刷新的页面加以下js $(function () { var isPageHide = false; window.addEventListener('pageshow', fun ...
- Kafka的特点及使用场景
Kafka是分布式发布-订阅消息系统.它最初由LinkedIn公司开发,之后成为Apache项目的一部分.Kafka是一个分布式的,可划分的,冗余备份的持久性的日志服务.它主要用于处理活跃的流式数据. ...
- C# war3 巨魔精灵 minimap
弃坑LOL后,无聊的时候玩玩 war3的RPG地图,巨魔与精灵. 玩了一段时间精灵....然后玩魔结果总是找不到人.所以就有了这个想法. 代码纯粹靠搬运. 说下原理,网上有份代码,可以查看当前选中目 ...
- 推荐一个比HtmlWebpackPlugin更灵活的插件
插件:html-res-webpack-plugin https://github.com/lcxfs1991/html-res-webpack-plugin/blob/v3/README_ZH.md ...
- CSS3让长单词与URL地址自动换行——word-wrap属性
div{ word-wrap:break-word; } word-wrap属性可以使用的属性值为normal与break-word两个.使用normal属性值时浏览器默认处理,只在半角空格或者连字符 ...
- BZOJ:4827: [Hnoi2017]礼物
[问题描述] 我的室友最近喜欢上了一个可爱的小女生.马上就要到她的生日了,他决定买一对情侣手 环,一个留给自己,一个送给她.每个手环上各有 n 个装饰物,并且每个装饰物都有一定的亮度. 但是在她生日的 ...
- Gym 100952G&&2015 HIAST Collegiate Programming Contest G. The jar of divisors【简单博弈】
G. The jar of divisors time limit per test:2 seconds memory limit per test:64 megabytes input:standa ...
- HDU 2079 dp解法
选课时间(题目已修改,注意读题) Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...