python中MySQLdb模块用法实例


Posted in Python onNovember 10, 2014

本文实例讲述了python中MySQLdb模块用法。分享给大家供大家参考。具体用法分析如下:

MySQLdb其实有点像php或asp中连接数据库的一个模式了,只是MySQLdb是针对mysql连接了接口,我们可以在python中连接MySQLdb来实现数据的各种操作。

python连接mysql的方案有oursql、PyMySQL、 myconnpy、MySQL Connector 等,不过本篇要说的确是另外一个类库MySQLdb,MySQLdb 是用于Python链接Mysql数据库的接口,它实现了 Python 数据库 API 规范 V2.0,基于 MySQL C API 上建立的。可以从:https://pypi.python.org/pypi/MySQL-python 进行获取和安装,而且很多发行版的linux源里都有该模块,可以直接通过源安装。

一、数据库连接

MySQLdb提供了connect方法用来和数据库建立连接,接收数个参数,返回连接对象:

conn=MySQLdb.connect(host="localhost",user="root",passwd="3water",db="test",charset="utf8")

比较常用的参数包括:
host:数据库主机名.默认是用本地主机
user:数据库登陆名.默认是当前用户
passwd:数据库登陆的秘密.默认为空
db:要使用的数据库名.没有默认值
port:MySQL服务使用的TCP端口.默认是3306
charset:数据库编码
更多关于参数的信息可以查这里 http://mysql-python.sourceforge.net/MySQLdb.html

然后,这个连接对象也提供了对事务操作的支持,标准的方法:
commit() 提交
rollback() 回滚

看一个简单的查询示例如下:

#!/usr/bin/python

# encoding: utf-8

import MySQLdb

# 打开数据库连接

db = MySQLdb.connect("localhost","root","361way","test" )

# 使用cursor()方法获取操作游标

cursor = db.cursor()

# 使用execute方法执行SQL语句

cursor.execute("SELECT VERSION()")

# 使用 fetchone() 方法获取一条数据库。

data = cursor.fetchone()

print "Database version : %s " % data

# 关闭数据库连接

db.close()

脚本执行结果如下:
Database version : 5.5.40

二、cursor方法执行与返回值

cursor方法提供两类操作:1.执行命令,2.接收返回值 。
cursor用来执行命令的方法

//用来执行存储过程,接收的参数为存储过程名和参数列表,返回值为受影响的行数

callproc(self, procname, args)

//执行单条sql语句,接收的参数为sql语句本身和使用的参数列表,返回值为受影响的行数

execute(self, query, args)

//执行单挑sql语句,但是重复执行参数列表里的参数,返回值为受影响的行数

executemany(self, query, args)

//移动到下一个结果集

nextset(self)

cursor用来接收返回值的方法

//接收全部的返回结果行.

fetchall(self)

//接收size条返回结果行.如果size的值大于返回的结果行的数量,则会返回cursor.arraysize条数据

fetchmany(self, size=None)

//返回一条结果行

fetchone(self)

//移动指针到某一行.如果mode='relative',则表示从当前所在行移动value条,如果mode='absolute',则表示从结果集的第一行移动value条

scroll(self, value, mode='relative')

//这是一个只读属性,并返回执行execute()方法后影响的行数

rowcount

三、数据库操作

1、创建database tables
如果数据库连接存在我们可以使用execute()方法来为数据库创建表,如下所示创建表EMPLOYEE:

#!/usr/bin/python

# encoding: utf-8

import MySQLdb

# 打开数据库连接

db = MySQLdb.connect("localhost","root","361way","test" )

# 使用cursor()方法获取操作游标

cursor = db.cursor()

# 如果数据表已经存在使用 execute() 方法删除表。

cursor.execute("DROP TABLE IF EXISTS EMPLOYEE")

# 创建数据表SQL语句

sql = """CREATE TABLE EMPLOYEE (

         FIRST_NAME  CHAR(20) NOT NULL,

         LAST_NAME  CHAR(20),

         AGE INT,

         SEX CHAR(1),

         INCOME FLOAT )"""

cursor.execute(sql)

# 关闭数据库连接

db.close()

2、数据库插入操作
#!/usr/bin/python

# encoding: utf-8

import MySQLdb

# 打开数据库连接

db = MySQLdb.connect("localhost","root","361way","test" )

# 使用cursor()方法获取操作游标

cursor = db.cursor()

# SQL 插入语句

sql = """INSERT INTO EMPLOYEE(FIRST_NAME,

         LAST_NAME, AGE, SEX, INCOME)

         VALUES ('Mac', 'Mohan', 20, 'M', 2000)"""

try:

   # 执行sql语句

   cursor.execute(sql)

   # 提交到数据库执行

   db.commit()

except:

   # Rollback in case there is any error

   db.rollback()

# 关闭数据库连接

db.close()

这里是一个单sql 执行的示例,cursor.executemany的用法感兴趣的读者可以参看相关的aws主机资产管理系统示例。
上例也可以写成通过占位符传参的方式进行执行,如下:
#!/usr/bin/python

# encoding: utf-8

import MySQLdb

# 打开数据库连接

db = MySQLdb.connect("localhost","testuser","test123","TESTDB" )

# 使用cursor()方法获取操作游标

cursor = db.cursor()

# SQL 插入语句

sql = "INSERT INTO EMPLOYEE(FIRST_NAME, \

       LAST_NAME, AGE, SEX, INCOME) \

       VALUES ('%s', '%s', '%d', '%c', '%d' )" % \

       ('Mac', 'Mohan', 20, 'M', 2000)

try:

   # 执行sql语句

   cursor.execute(sql)

   # 提交到数据库执行

   db.commit()

except:

   # 发生错误时回滚

   db.rollback()

# 关闭数据库连接

db.close()

也可以以变量的方式传递参数,如下:
..................................

user_id = "test"

password = "password123"

con.execute('insert into Login values("%s", "%s")' % \

             (user_id, password))

..................................

3、数据库查询操作
以查询EMPLOYEE表中salary(工资)字段大于1000的所有数据为例:
#!/usr/bin/python

# encoding: utf-8

import MySQLdb

# 打开数据库连接

db = MySQLdb.connect("localhost","root","361way","test" )

# 使用cursor()方法获取操作游标

cursor = db.cursor()

# SQL 查询语句

sql = "SELECT * FROM EMPLOYEE \

       WHERE INCOME > '%d'" % (1000)

try:

   # 执行SQL语句

   cursor.execute(sql)

   # 获取所有记录列表

   results = cursor.fetchall()

   for row in results:

      fname = row[0]

      lname = row[1]

      age = row[2]

      sex = row[3]

      income = row[4]

      # 打印结果

      print "fname=%s,lname=%s,age=%d,sex=%s,income=%d" % \

             (fname, lname, age, sex, income )

except:

   print "Error: unable to fecth data"

# 关闭数据库连接

db.close()

以上脚本执行结果如下:
fname=Mac, lname=Mohan, age=20, sex=M, income=2000

4、数据库更新操作
更新操作用于更新数据表的的数据,以下实例将 test表中的 SEX 字段全部修改为 'M',AGE 字段递增1:

# encoding: utf-8

#!/usr/bin/python

import MySQLdb

# 打开数据库连接

db = MySQLdb.connect("localhost","root","361way","test" )

# 使用cursor()方法获取操作游标

cursor = db.cursor()

# SQL 更新语句

sql = "UPDATE EMPLOYEE SET AGE = AGE + 1

                          WHERE SEX = '%c'" % ('M')

try:

   # 执行SQL语句

   cursor.execute(sql)

   # 提交到数据库执行

   db.commit()

except:

   # 发生错误时回滚

   db.rollback()

# 关闭数据库连接

db.close()

5、执行事务

事务机制可以确保数据一致性。
事务应该具有4个属性:原子性、一致性、隔离性、持久性。这四个属性通常称为ACID特性。
① 原子性(atomicity)。一个事务是一个不可分割的工作单位,事务中包括的诸操作要么都做,要么都不做。
② 一致性(consistency)。事务必须是使数据库从一个一致性状态变到另一个一致性状态。一致性与原子性是密切相关的。
③ 隔离性(isolation)。一个事务的执行不能被其他事务干扰。即一个事务内部的操作及使用的数据对并发的其他事务是隔离的,并发执行的各个事务之间不能互相干扰。
④ 持久性(durability)。持续性也称永久性(permanence),指一个事务一旦提交,它对数据库中数据的改变就应该是永久性的。接下来的其他操作或故障不应该对其有任何影响。

Python DB API 2.0 的事务提供了两个方法 commit 或 rollback。实例:

# SQL删除记录语句

sql = "DELETE FROM EMPLOYEE WHERE AGE > '%d'" % (20)

try:

   # 执行SQL语句

   cursor.execute(sql)

   # 向数据库提交

   db.commit()

except:

   # 发生错误时回滚

   db.rollback()

对于支持事务的数据库, 在Python数据库编程中,当游标建立之时,就自动开始了一个隐形的数据库事务。commit()方法游标的所有更新操作,rollback()方法回滚当前游标的所有操作。每一个方法都开始了一个新的事务。

希望本文所述对大家的Python程序设计有所帮助。

Python 相关文章推荐
python thread 并发且顺序运行示例
Apr 09 Python
python发送邮件示例(支持中文邮件标题)
Feb 16 Python
Python Queue模块详解
Nov 30 Python
Python脚本实现DNSPod DNS动态解析域名
Feb 14 Python
python使用super()出现错误解决办法
Aug 14 Python
Python+selenium实现自动循环扔QQ邮箱漂流瓶
May 29 Python
使用python打印十行杨辉三角过程详解
Jul 10 Python
python Popen 获取输出,等待运行完成示例
Dec 30 Python
Python 如何批量更新已安装的库
May 26 Python
基于python代码批量处理图片resize
Jun 04 Python
Tensorflow全局设置可见GPU编号操作
Jun 30 Python
Python3 pyecharts生成Html文件柱状图及折线图代码实例
Sep 29 Python
Python实现子类调用父类的方法
Nov 10 #Python
Python模仿POST提交HTTP数据及使用Cookie值的方法
Nov 10 #Python
Python类的多重继承问题深入分析
Nov 09 #Python
python查询mysql中文乱码问题
Nov 09 #Python
python刷投票的脚本实现代码
Nov 08 #Python
Django静态资源URL STATIC_ROOT的配置方法
Nov 08 #Python
Python中的__new__与__init__魔术方法理解笔记
Nov 08 #Python
You might like
php中设置多级目录session的问题
2011/08/08 PHP
动态表单验证的操作方法和TP框架里面的ajax表单验证
2017/07/19 PHP
asp.net和asp下ACCESS的参数化查询
2008/06/11 Javascript
Prototype使用指南之selector.js说明
2008/10/26 Javascript
js导出txt示例代码
2014/01/14 Javascript
多种方法实现load加载完成后把图片一次性显示出来
2014/02/19 Javascript
js获取和设置属性的方法
2014/02/20 Javascript
JavaScript获取页面中超链接数量的方法
2015/11/09 Javascript
正则表达式优化JSON字符串的技巧
2015/12/24 Javascript
浅谈AngularJs指令之scope属性详解
2016/10/24 Javascript
jQuery中checkbox反复调用attr('checked', true/false)只有第一次生效的解决方法
2016/11/16 Javascript
详解Angularjs 如何自定义Img的ng-load 事件
2017/02/15 Javascript
使用SVG基本操作API的实例讲解
2017/09/14 Javascript
Vue内部渲染视图的方法
2019/09/02 Javascript
基于node+vue实现简单的WebSocket聊天功能
2020/02/01 Javascript
vue-socket.io接收不到数据问题的解决方法
2020/05/13 Javascript
vue+echarts实现动态折线图的方法与注意
2020/09/01 Javascript
[01:05:12]2014 DOTA2国际邀请赛中国区预选赛 TongFu VS CIS-GAME
2014/05/21 DOTA
[01:07:22]2014 DOTA2华西杯精英邀请赛 5 24 DK VS VG加赛
2014/05/26 DOTA
在Python中使用itertools模块中的组合函数的教程
2015/04/13 Python
Python中join和split用法实例
2015/04/14 Python
python妹子图简单爬虫实例
2015/07/07 Python
Python 元类实例解析
2018/04/04 Python
Python类装饰器实现方法详解
2018/12/21 Python
python实现上传文件到linux指定目录的方法
2020/01/03 Python
python列表推导和生成器表达式知识点总结
2020/01/10 Python
PyCharm License Activation激活码失效问题的解决方法(图文详解)
2020/03/12 Python
HTML5如何使用SVG的方法示例
2019/01/11 HTML / CSS
美国著名的家居用品购物网站:Bed Bath & Beyond
2018/01/05 全球购物
春节活动策划方案
2014/01/24 职场文书
学生会个人自荐书范文
2014/02/12 职场文书
请假条范文大全
2014/04/10 职场文书
党校培训自我鉴定范文
2014/04/10 职场文书
离婚协议书的范本
2015/01/27 职场文书
运动会800米赞词
2015/07/22 职场文书
vue项目打包后路由错误的解决方法
2022/04/13 Vue.js