一、简介:

  MySQL为关系型数据库,其他关系型数据库包括Oracle、DB2、Sql Server等等。Python操作MySQL需要使用到pymsyql模块,pip安装即可。

二、操作MySQL步骤

  1、连上数据库(IP、端口号、用户名、密码、数据库名)

  2、建立游标

  3、执行sql

  4、获取结果

  5、关闭游标

  6、关闭连接

 import pymysql
conn = pymysql.connect(
host='192.168.1.112',
user='test',
passwd='',
port=3306, # port必须是int类型
db='test',
charset='utf8' # charset必须写utf8,不能写utf-8
)
sqla = 'select * from stu limit 10;'
sqlb = 'insert into stu (id,name,sex) VALUE (10000,"张流量","女");'
cur = conn.cursor() # 建立游标,不指定cursor类型返回的是二维元组
cur = conn.cursor(cursor=pymysql.cursors.DictCursor) # 建立游标,指定cursor类型返回的是字典
cur.execute(sqla) # 执行sqla
cur.execute(sqlb) # 执行sqlb
conn.commit() # 执行insert、delete、update语句必须commit
res = cur.fetchall() # 执行所有返回的结果,fetchall返回的是一个二维数组
res = cur.fetchone() # 执行所有返回的结果,fetchone返回的是第一行
res = cur.fetchmany(2) # 执行所有返回的结果,fetchmany传入一个数返回多少条数据
res = cur.description # 返回表中每个字段的信息,description返回的也是一个二维数组
print(res)
cur.close() # 关闭游标
conn.close() # 关闭连接

Cursor类型:

  不指定cursor类型,即:cur = conn.cursor(),则返回的结果是:((5, 'Ben', 男'), (6, 'Lily', 女')),是一个二维的元组

  指定curson类型,即:cur = conn.cursor(cursor=pymysql.cursors.DictCursor),则返回的结果是:

  [{'id': 5, 'name': 'Ben', 'sex': '男'}, {'id': 6, 'name': 'Lily', 'sex': '女'}]

fetchall()和fetchone()的区别:

  fetchall():获取到这个sql执行的全部结果,它把数据库表中的每一行数据放到一个元组或字典里面

  fetchone():获取到这个sql执行的一条结果,它返回的只是一条数据

  如果sql语句执行的结果是多条数据的时候,那就用 fetchall(),如果能确定sql执行的结果只有一条,那就用fetchone()

三、封装操作MySQL数据库的函数

 def my_db(sql,port=3306,charset='utf8'):
import pymysql
host,user,passwd,db = '192.168.1.112','test','','test' # 定义变量
conn = pymysql.connect(host=host,
user=user,
passwd=passwd,
port=port,
db=db,
charset=charset)
cur = conn.cursor(cursor=pymysql.cursors.DictCursor) # 建立游标,指定cursor类型返回的是字典
cur.execute(sql) # 执行语句
if sql.strip().split()[0].upper() == 'SELECT': # 判断sql语句是否以select开头
res = cur.fetchall()
else:
conn.commit()
res = 'OK'
cur.close() # 关闭游标
conn.close() # 关闭连接
return res

四、练习

  传入一个表名,把所有数据导出,写入excel文件

 def export_excel(table_name):
import pymysql,xlwt
conn = pymysql.connect(
host='118.24.3.40',
user='jxz',
passwd='',
port=3306,
db='jxz',
charset='utf8')
sql = 'select * from %s;'%table_name
cur = conn.cursor() # 建立游标,不指定cursor类型返回的是二维元组
cur.execute(sql) # 执行sql
all_data = cur.fetchall() # 获取表中所有数据
fileds = [filed[0] for filed in cur.description] # 获取表的所有字段存入一个list里面
book = xlwt.Workbook() # 新建一个excel
sheet = book.add_sheet('sheet1') # 增加sheet页
for col,filed in enumerate(fileds):
sheet.write(0,col,filed) # 将表头写入excel文件中的第一行
row = 1 # 定义行数
for data in all_data: # 控制行
for col,filed in enumerate(data):#控制列
sheet.write(row,col,filed)
row = row + 1 # 每次写完一行,行加1
book.save('%s.xls'%table_name)

Python学习之==>操作MySQL的更多相关文章

  1. python学习之操作mysql

    欢迎点击个人博客 http://www.iwangzheng.com/ 刚开始学python,所以很多代码都需要在ipython里尝试一下.今天记录的是最基本的操作mysql数据库. 写数据库连接操作 ...

  2. [Python] 学习笔记之MySQL数据库操作

    1 Python标准数据库接口DB-API介绍 Python标准数据库接口为 Python DB-API,它为开发人员提供了数据库应用编程接口.Python DB-API支持很多种的数据库,你可以选择 ...

  3. 【Python】python读取文件操作mysql

    尾大不掉,前阵子做检索测试时,总是因为需要业务端操作db和一些其他服务,这就使得检索测试对环境和数据依赖性特别高,极大提高了测试成本. Mock服务和mysql可以很好的解决这个问题,所以那阵子做了两 ...

  4. python大法好——操作mysql

    python操作mysql数据库 Python 标准数据库接口为 Python DB-API,Python DB-API为开发人员提供了数据库应用编程接口. Python 数据库接口支持非常多的数据库 ...

  5. python开发_python操作mysql数据库

    如果你还没有准备好开发环境,你不妨花上一小点时间去看看:python开发_mysqldb安装 本篇blog是有关python操作mysql数据的相关内容. 我做了一个demo: 先看运行效果: mys ...

  6. 10 python学习笔记-操作数据库(十)

    在功能.接口测试中,常常需要通过数据库的操作,来准备数据.检测环境及核对功能.接口的数据库操作是否正确. 在自动化测试中,就需要我们用代码连接数据库自动完成数据准备. 环境检查及数据库断言的功能.数据 ...

  7. Python使用DB-API操作MySQL数据库

    Python提供了一个标准数据库API,称为DB-API,用于处理基于SQL的数据库.与任何底层数据库的交互都可以使用DB-API,因为DB-API在代码与驱动程序之间提供了一个抽象层,可以根据需要替 ...

  8. Python学习-list操作

    Python列表(list)操作: 序列是Python中最基本的数据结构.序列中的每个元素都分配一个数字 - 它的位置,或索引,第一个索引是0,第二个索引是1,依此类推. Python有6个序列的内置 ...

  9. python学习道路(day12note)(mysql操作,python链接mysql,redis)

    1,针对mysql操作 SET PASSWORD FOR 'root'@'localhost' = PASSWORD('newpass'); 设置密码 update user set password ...

随机推荐

  1. nova计算服务分布式

    控制节点 #第一步 控制节点下载nova-conpute包 #安装依赖包 #vim /etc/nova/nova.conf [DEFAULT] my_ip=#当前节点IP use_neutron = ...

  2. Qualcomm_Mobile_OpenCL.pdf 翻译-2

    2  Opencl的简介 这一章主要讨论Opencl标准中的关键概念和在手机平台上开发Opencl程序的基础知识.如果想知道关于Opencl更详细的知识,请查阅参考文献中的<The OpenCL ...

  3. 【转】Linux添加虚拟网卡

    转自:https://blog.csdn.net/hzhsan/article/details/44677867 有时候,一台服务器需要设置多个ip,但又不想添加多块网卡,那就需要设置虚拟网卡.这里介 ...

  4. 2018牛客网暑期ACM多校训练营(第十场)J Rikka with Nickname(二分,字符串)

    链接:https://ac.nowcoder.com/acm/contest/148/J?&headNav=acm 来源:牛客网 Rikka with Nickname 时间限制:C/C++ ...

  5. [BZOJ1299]巧克力棒(博弈论,线性基)

    [BZOJ1299]巧克力棒 Description TBL和X用巧克力棒玩游戏.每次一人可以从盒子里取出若干条巧克力棒,或是将一根取出的巧克力棒吃掉正整数长度.TBL先手两人轮流,无法操作的人输. ...

  6. gdb命令小结

    GDB命令小结 gdb <filename> : 调试指定程序文件 r : run 的简写,运行被调试程序, 如果此前没有下过断点,则执行完整个程序:如果有断点, 则程序暂停在第一个可用断 ...

  7. 【shell】文本按行逆序

    1.最简单的方法是使用tac [root ~]$ seq |tac 2.使用tr和awk. tr把换行符替换成自定义的分隔符,awk分解替换后的字符串,并逆序输出 [root ~]$ seq | tr ...

  8. Python 列表(List)Ⅰ

    Python 列表(List) 序列是Python中最基本的数据结构.序列中的每个元素都分配一个数字 - 它的位置,或索引,第一个索引是0,第二个索引是1,依此类推. Python有6个序列的内置类型 ...

  9. redis 日志等级说明

    redis loglevel 安装默认的设置为 verbose 1)debug:会打印出很多信息,适用于开发和测试阶段 2)verbose(冗长的):包含很多不太有用的信息,但比debug要清晰一些 ...

  10. 把数据存储到 XML 文件

    通常,我们在数据库中存储数据.不过,如果希望数据的可移植性更强,我们可以把数据存储 XML 文件中. 创建并保存 XML 文件 如果数据要被传送到非 Windows 平台上的应用程序,那么把数据保存在 ...