本文介绍了 Python 操作 MYSQL、执行 SQL 语句、获取结果集、遍历结果集、取得某个字 段、获取表字段名、将图片插入数据库、执行事务等各种代码实例和详细介绍,代码居多, 是一桌丰盛唯美的代码大餐。
实例 1、取得 MYSQL 的版本 在 windows 环境下安装 mysql 模块用于 python 开发,请见我的另一篇文章:
MySQL-python Windows 下 EXE 安装文件下载 # -*- coding: UTF-8 -*-
 
#安装 MYSQL DB for python import MySQLdb as mdb
 
con = None
 
try:     #连接 mysql 的方法:connect('ip','user','password','dbname')     con = mdb.connect('localhost', 'root',         'root', 'test');
 
    #所有的查询,都在连接 con 的一个模块 cursor 上面运行的     cur = con.cursor()
 
    #执行一个查询     cur.execute("SELECT VERSION()")
 
    #取得上个查询的结果,是单个结果     data = cur.fetchone()     print "Database version %s " % data finally:     if con:         #无论如何,连接记得关闭         con.close() 执行结果:
Database version : 5.5.25
实例 2、创建一个表并且插入数据 主要还是在 cursor 上面执行 execute 方法来进行,请见源码:

# -*- coding: UTF-8 -*-
# 来源于 www.crazyant.net 总结整理
import MySQLdb as mdb import sys
 
#将 con 设定为全局连接 con = mdb.connect('localhost', 'root', 'root', 'test');
 
with con:
 
    #获取连接的 cursor,只有获取了 cursor,我们才能进行各种操作     cur = con.cursor()     #创建一个数据表 writers(id,name)     cur.execute("CREATE TABLE IF NOT EXISTS \         Writers(Id INT PRIMARY KEY AUTO_INCREMENT, Name VARCHAR(25))")     #以下插入了 5 条数据     cur.execute("INSERT INTO Writers(Name) VALUES('Jack London')")     cur.execute("INSERT INTO Writers(Name) VALUES('Honore de Balzac')")     cur.execute("INSERT INTO Writers(Name) VALUES('Lion Feuchtwanger')")     cur.execute("INSERT INTO Writers(Name) VALUES('Emile Zola')")     cur.execute("INSERT INTO Writers(Name) VALUES('Truman Capote')") 运行结果(在 phpmyadmin 中查看,在 mysql 命令行查看结果是一样的):
来源:疯狂的蚂蚁的博客 www.crazyant.net 总结和整理
 
实例 3、python 使用 slect 获取 mysql 的数据并遍 历
这个恐怕是用的最多的了,请速看代码:
# -*- coding: UTF-8 -*-
# 来源:www.crazyant.net 整理总结
import MySQLdb as mdb import sys
 
#连接 mysql,获取连接的对象 con = mdb.connect('localhost', 'root', 'root', 'test');
 
with con:     #仍然是,第一步要获取连接的 cursor 对象,用于执行查询     cur = con.cursor()     #类似于其他语言的 query 函数,execute 是 python 中的执行查询函数     cur.execute("SELECT * FROM Writers")
 
    #使用 fetchall 函数,将结果集(多维元组)存入 rows 里面
来源:疯狂的蚂蚁的博客 www.crazyant.net 总结和整理
    rows = cur.fetchall()
 
    #依次遍历结果集,发现每个元素,就是表中的一条记录,用一个元组来显示     for row in rows:         print row 运行结果:
(1L, ‘Jack London’) (2L, ‘Honore de Balzac’) (3L, ‘Lion Feuchtwanger’) (4L, ‘Emile Zola’) (5L, ‘Truman Capote’)
上面的代码,用来将所有的结果取出,不过打印的时候是每行一个元祖打印,现在我们使用 方法,取出其中的单个数据:
# -*- coding: UTF-8 -*-

import MySQLdb as mdb import sys
 
#获取 mysql 的链接对象 con = mdb.connect('localhost', 'root', 'root', 'test');
 
with con:     #获取执行查询的对象     cur = con.cursor()
 
    #执行那个查询,这里用的是 select 语句     cur.execute("SELECT * FROM Writers")
 
    #使用 cur.rowcount 获取结果集的条数     numrows = int(cur.rowcount)
 
    #循环 numrows 次,每次取出一行数据     for i in range(numrows):         #每次取出一行,放到 row 中,这是一个元组(id,name)         row = cur.fetchone()         #直接输出两个元素         print row[0], row[1]
 
来源:疯狂的蚂蚁的博客 www.crazyant.net 总结和整理
运行结果:
1 Jack London 2 Honore de Balzac 3 Lion Feuchtwanger 4 Emile Zola 5 Truman Capote
 numrows = int(cur.rowcount)用于获取结果集的数目  row = cur.fetchone()每次取出一行数据,同时记录集的指针执行下一行 实例 4、使用字典 cursor 取得结果集(可以使用表 字段名字访问值)
# -*- coding: UTF-8 -*-
# 来源:疯狂的蚂蚁的博客 www.crazyant.net 总结整理
import MySQLdb as mdb import sys
 
#获得 mysql 查询的链接对象 con = mdb.connect('localhost', 'root', 'root', 'test')
 
with con:     #获取连接上的字典 cursor,注意获取的方法,     #每一个 cursor 其实都是 cursor 的子类     cur = con.cursor(mdb.cursors.DictCursor)
 
    #执行语句不变     cur.execute("SELECT * FROM Writers")
 
    #获取数据方法不变     rows = cur.fetchall()
 
    #遍历数据也不变(比上一个更直接一点)     for row in rows:         #这里,可以使用键值对的方法,由键名字来获取数据         print "%s %s" % (row["Id"], row["Name"])  
 
来源:疯狂的蚂蚁的博客 www.crazyant.net 总结和整理
实例 5、获取单个表的字段名和信息的方法
# -*- coding: UTF-8 -*-

import MySQLdb as mdb import sys
 
#获取数据库的链接对象 con = mdb.connect('localhost', 'root', 'root', 'test')
 
with con:     #获取普通的查询 cursor     cur = con.cursor()     cur.execute("SELECT * FROM Writers")
 
    rows = cur.fetchall()
 
    #获取连接对象的描述信息     desc = cur.description     print 'cur.description:',desc
 
    #打印表头,就是字段名字     print "%s %3s" % (desc[0][0], desc[1][0])
 
    for row in rows:         #打印结果         print "%2s %3s" % row 运行结果:
cur.description: ((‘Id’, 3, 1, 11, 11, 0, 0), (‘Name’, 253, 17, 25, 25, 0, 1)) Id Name 1 Jack London 2 Honore de Balzac 3 Lion Feuchtwanger 4 Emile Zola 5 Truman Capote
实例 6、使用 Prepared statements 执行查询(更 安全方便)
# -*- coding: UTF-8 -*-
来源:疯狂的蚂蚁的博客 www.crazyant.net 总结和整理
# 来源:疯狂的蚂蚁的博客 www.crazyant.net 总结整理
import MySQLdb as mdb import sys
 
con = mdb.connect('localhost', 'root', 'root', 'test')
 
with con:    
 
    cur = con.cursor()     #我们看到,这里可以通过写一个可以组装的 sql 语句来进行     cur.execute("UPDATE Writers SET Name = %s WHERE Id = %s",         ("Guy de Maupasant", "4"))     #使用 cur.rowcount 获取影响了多少行     print "Number of rows updated: %d" % cur.rowcount 结果:
Number of rows updated: 1
实例 7、把图片用二进制存入 MYSQL 有人喜欢把图片存入 MYSQL(这种做法貌似很少吧),我看大部分的程序,图片都是存放 在服务器上的文件,数据库中存的只是图片的地址而已,不过 MYSQL 是支持把图片存入数 据库的,也相应的有一个专门的字段 BLOB (Binary Large Object),即较大的二进制对象 字段,请看如下程序,注意测试图片自己随便找一个,地址要正确: 首先,在数据库中创建一个表,用于存放图片:
CREATE TABLE Images(Id INT PRIMARY KEY AUTO_INCREMENT, Data MEDIUMBLOB);
然后运行如下 PYTHON 代码进行:
# -*- coding: UTF-8 -*-
# 来源:疯狂的蚂蚁的博客 www.crazyant.net 总结整理
import MySQLdb as mdb import sys
 
try:     #用读文件模式打开图片     fin = open("../web.jpg")     #将文本读入 img 对象中     img = fin.read()     #关闭文件
来源:疯狂的蚂蚁的博客 www.crazyant.net 总结和整理
    fin.close()
 
except IOError, e:     #如果出错,打印错误信息     print "Error %d: %s" % (e.args[0],e.args[1])     sys.exit(1)
 
try:     #链接 mysql,获取对象     conn = mdb.connect(host='localhost',user='root',passwd='root', db='test')     #获取执行 cursor     cursor = conn.cursor()     #直接将数据作为字符串,插入数据库     cursor.execute("INSERT INTO Images SET Data='%s'" % mdb.escape_string(img))
 
    #提交数据     conn.commit()
 
    #提交之后,再关闭 cursor 和链接     cursor.close()     conn.close()
 
except mdb.Error, e:     #若出现异常,打印信息     print "Error %d: %s" % (e.args[0],e.args[1])     sys.exit(1) 结果: 
 
 

 escape_string 函数将插入数据库的字符串进行转义,这会指一些 SQL 注入的攻击

实例 8、从数据库中把图片读出来
# -*- coding: UTF-8 -*-

import MySQLdb as mdb import sys
 
try:     #连接 mysql,获取连接的对象     conn = mdb.connect('localhost', 'root', 'root', 'test');
 
    cursor = conn.cursor()
 
    #执行查询该图片字段的 SQL     cursor.execute("SELECT Data FROM Images LIMIT 1")
 
    #使用二进制写文件的方法,打开一个图片文件,若不存在则自动创建     fout = open('image.png','wb')     #直接将数据如文件     fout.write(cursor.fetchone()[0])     #关闭写入的文件     fout.close()
 
    #释放查询数据的资源     cursor.close()     conn.close()
 
except IOError, e:     #捕获 IO 的异常 ,主要是文件写入会发生错误     print "Error %d: %s" % (e.args[0],e.args[1])     sys.exit(1)

实例 9、使用 Transaction 即事务(手动提交,自 动回滚)
# -*- coding: UTF-8 -*-
# 来源:疯狂的蚂蚁的博客 www.crazyant.net 总结整理
import MySQLdb as mdb import sys
来源:疯狂的蚂蚁的博客 www.crazyant.net 总结和整理
 
try:     #连接 mysql,获取连接的对象     conn = mdb.connect('localhost', 'root', 'root', 'test');
 
    cursor = conn.cursor()     #如果某个数据库支持事务,会自动开启     #这里用的是 MYSQL,所以会自动开启事务(若是 MYISM 引擎则不会)     cursor.execute("UPDATE Writers SET Name = %s WHERE Id = %s",         ("Leo Tolstoy", "1"))     cursor.execute("UPDATE Writers SET Name = %s WHERE Id = %s",         ("Boris Pasternak", "2"))     cursor.execute("UPDATE Writer SET Name = %s WHERE Id = %s",         ("Leonid Leonov", "3"))   
 
    #事务的特性 1、原子性的手动提交     conn.commit()
 
    cursor.close()     conn.close()
 
except mdb.Error, e:     #如果出现了错误,那么可以回滚,就是上面的三条语句要么执行,要么都不执行     conn.rollback()     print "Error %d: %s" % (e.args[0],e.args[1]) 结果:
1、因为不存在 writer 表(SQL 第三条语句),所以出现错误: Error 1146: Table ‘test.writer’ doesn’t exist
2、出现错误,出发异常处理,3 条语句的前两条会自动变成了没有执行,结果不变
3、如果本代码放到一个 MyISAM 引擎表,前两句会执行,第三句不会;如果是 INNDB 引 擎,则都不会执行。

Python 操作 MYSQL的更多相关文章

  1. Python(九) Python 操作 MySQL 之 pysql 与 SQLAchemy

    本文针对 Python 操作 MySQL 主要使用的两种方式讲解: 原生模块 pymsql ORM框架 SQLAchemy 本章内容: pymsql 执行 sql 增\删\改\查 语句 pymsql ...

  2. 练习:python 操作Mysql 实现登录验证 用户权限管理

    python 操作Mysql 实现登录验证 用户权限管理

  3. Python操作MySQL

    本篇对于Python操作MySQL主要使用两种方式: 原生模块 pymsql ORM框架 SQLAchemy pymsql pymsql是Python中操作MySQL的模块,其使用方法和MySQLdb ...

  4. Python操作Mysql之基本操作

    pymysql python操作mysql依赖pymysql这个模块 下载安装 pip3 install pymysql 操作mysql python操作mysql的时候,是通过”游标”来进行操作的. ...

  5. python成长之路【第十三篇】:Python操作MySQL之pymysql

    对于Python操作MySQL主要使用两种方式: 原生模块 pymsql ORM框架 SQLAchemy pymsql pymsql是Python中操作MySQL的模块,其使用方法和MySQLdb几乎 ...

  6. python操作mysql数据库的相关操作实例

    python操作mysql数据库的相关操作实例 # -*- coding: utf-8 -*- #python operate mysql database import MySQLdb #数据库名称 ...

  7. Python 操作 MySQL 之 pysql 与 ORM(转载)

    本文针对 Python 操作 MySQL 主要使用的两种方式讲解: 原生模块 pymsql ORM框架 SQLAchemy 本章内容: pymsql 执行 sql 增\删\改\查 语句 pymsql ...

  8. Python开发【第十九篇】:Python操作MySQL

    本篇对于Python操作MySQL主要使用两种方式: 原生模块 pymsql ORM框架 SQLAchemy pymsql pymsql是Python中操作MySQL的模块,其使用方法和MySQLdb ...

  9. Python操作Mysql实例代码教程在线版(查询手册)

    本文介绍了Python操作MYSQL.执行SQL语句.获取结果集.遍历结果集.取得某个字段.获取表字段名.将图片插入数据库.执行事务等各种代码实例和详细介绍,代码居多,是一桌丰盛唯美的代码大餐   实 ...

  10. Python操作MySQL以及中文乱码的问题

    Python操作MySQL需要安装Python-MySQL可以从网上搜索一下,和一般的Python包一样安装 安装好之后,模块名字叫做MySQLdb ,在Window和Linux环境下都可以使用,试验 ...

随机推荐

  1. javaWeb学习总结(7)-会话之session技术

    什么是Session 使用Cookie和附加URL参数都可以将上一次请求的状态信息传递到下一次请求中,但是如果传递的状态信息较多,将极大降低网络传输效率和增大服务器端程序处理的难度. Session技 ...

  2. JQuery模拟实现天猫购物车动画效果

    测试程序源代码下载地址:源码 一.功能描述: 1.点击购买按钮,模拟抛物线将物品弹到购物车里: 2.购物车添加物品后,显示+1动画: 效果图如下: 实现如下: 1.导入jquery相关的包: < ...

  3. THREE笛卡尔右手坐标系详解

    1,正常的笛卡尔右手坐标系,以屏幕右方为+X轴,屏幕上方为+Y轴,垂直屏幕向外为+Z轴,如下图,xy轴组成的平面为屏幕面 但由于THREE里的相机并不总是从屏幕正前方视角,还可以设置坐标系任意一个轴为 ...

  4. glmnetUtils: quality of life enhancements for elastic net regression with glmnet

    The glmnetUtils package provides a collection of tools to streamline the process of fitting elastic ...

  5. maven spring mybatis配置注意点

    以下对使用maven配置spring+mybatis项目时,完成基本的配置需要添加的一些信息进行说明.仅对mybatis部分进行列举. maven添加mybatis支持 <!-- mybatis ...

  6. 虚拟机安装Android最详细教程

    虚拟机想必大家都听说过,有些同学还用过.虚拟机可以模拟出一个操作系统,基于物理机创建.可以模拟常见的 Windows,ubuntu等等. 在使用虚拟机的过程中,想必大家都遇到过一些棘手的问题,尤其是安 ...

  7. 加载jquery插件注意了

    1.尽量放在</body>之前,不要放在</head>标签之前,如果执意要放也要放在css之后,例如: <link href="style.css" ...

  8. python面向对象的编程

    self相当于在实例化类的过程中传入参数,实例化对象本身 静态方法,静态字段属于类,动态字段,动态方法输入每一个实例化的对象 类实例化的过程把一些属性,方法封装到一个实例化对象当中 动态字段,动态方法 ...

  9. git rebase -i命令修改commit历史

    [TOC] 修改commit历史的前提 修改历史的提交是可能有风险的,是否有风险取决于commit是否已经推送远程分支,未推送,无风险,如果已推送,就千万不要修改commit了. 修改commit历史 ...

  10. Bash启动选项

    Bash选项可以用来控制它的行为,有两种选项:单字符选项和多字符选项,多字符选项必须出现在单字符选项以前.1)单字符选项:由一个减号和一个字符组成2)多字符选项:由两个减号和多个字符组成 常用选项:- ...