在Windows平台上安装mysql模块用于Python开发
用python连接mysql的时候,需要用的安装版本,源码版本容易有错误提示。下边是打包了32与64版本。 3 b W) ^: t. j4 ^/ }0 S6 O6 j3 u
MySQL-python-1.2.3.win32-py2.7.exe 6 d+ \, u$ }: K" H+ c
MySQL-python-1.2.3.win-amd64-py2.7.exe. x9 \0 f# i" S, X% V
实例 1、取得 MYSQL 的版本
实例 2、创建一个表并且插入数据
import MySQLdb as mdbimport 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')")实例 3、 python 使用 slect 获取 mysql 的数据并遍历
import MySQLdb as mdbimport 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 里面rows = cur.fetchall()#依次遍历结果集,发现每个元素,就是表中的一条记录,用一个元组来显示for row in rows:print row运行结果:
(1L, ‘Jack London')
(2L, ‘Honore de Balzac')
(3L, ‘Lion Feuchtwanger')6 B) B; D* ]( E: r
(4L, ‘Emile Zola')% v. l) T$ a. r. H! s" O& G
(5L, ‘Truman Capote')
上面的代码,用来将所有的结果取出,不过打印的时候是每行一个元祖打印,现在我们使用方法,取出其中的单个数据:
运行结果:
1 Jack London9 L G: k/ x1 C" l4 p, ?8 f' ?7 S
2 Honore de Balzac
3 Lion Feuchtwanger; R" o ~* p' N/ [" V" S& r. e
4 Emile Zola
5 Truman Capote" a# G2 z; B$ y% v* y. q( }
实例 4、使用字典 cursor 取得结果集(可以使用表字段名字访问值)
实例 5、获取单个表的字段名和信息的方法
import MySQLdb as mdbimport sys#获取数据库的链接对象con = mdb.connect('localhost', 'root', 'root', 'test')with con:#获取普通的查询 cursorcur = con.cursor()cur.execute("SELECT * FROM Writers")rows = cur.fetchall()#获取连接对象的描述信息desc = cur.descriptionprint '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))" ^; ]3 [; T) Q4 M y1 b( o* e
Id Name& h; ]9 D" ~/ {
1 Jack London
2 Honore de Balzac& L, E) }2 V% G) V1 j! k
3 Lion Feuchtwanger4 ^) ]: d6 ?/ j
4 Emile Zola6 \" o9 M8 j- P4 y/ H+ |- |# M% M
5 Truman Capote, c, X. G. k# K7 }3 i5 T s/ f& U
实例 6、使用 Prepared statements 执行查询(更安全方便)
结果:
Number of rows updated: 1
实例 7、把图片用二进制存入 MYSQL
有人喜欢把图片存入 MYSQL(这种做法貌似很少吧),我看大部分的程序,图片都是存放在服务器上的文件,数据库中存的只是图片的地址而已,不过 MYSQL 是支持把图片存入数据库的,也相应的有一个专门的字段 BLOB (Binary Large Object),即较大的二进制对象字段,请看如下程序,注意测试图片自己随便找一个,地址要正确: / i( |7 \6 W' X7 \
首先,在数据库中创建一个表,用于存放图片:
然后运行如下 PYTHON 代码进行:
4 ]- o* ^5 X3 R# b2 x5 o
实例 8、从数据库中把图片读出来
import MySQLdb as mdbimport systry:#连接 mysql,获取连接的对象conn = mdb.connect('localhost', 'root', 'root', 'test');cursor = conn.cursor()#执行查询该图片字段的 SQLcursor.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)3 P6 R7 Q$ F" P x实例 9、使用 Transaction 即事务(手动提交,自动回滚)
import MySQLdb as mdbimport systry:#连接 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])2 e o: L; d( Q. v: `结果: T# @' k9 @: K4 o- v
1、因为不存在 writer 表( SQL 第三条语句),所以出现错误:Error 1146: Table ‘test.writer' doesn't exist
2、出现错误,出发异常处理, 3 条语句的前两条会自动变成了没有执行,结果不变 1 Y, \2 X- C3 i. o' r3 J" q3 s7 }
3、如果本代码放到一个 MyISAM 引擎表,前两句会执行,第三句不会;如果是 INNDB 引擎,则都不会执行。
| 欢迎光临 数学建模社区-数学中国 (http://www.madio.net/) | Powered by Discuz! X2.5 |