`

Python操作MySQL数据库实例

阅读更多

上次说到使用python制作人体艺术图片站点时,用到了python,但是如何使用python操作mysql数据库呢?接下来就是答案了

在Windows平台上安装mysql模块用于Python开发

用python连接mysql的时候,需要用的安装版本,源码版本容易有错误提示。下边是打包了32与64版本。 
MySQL-python-1.2.3.win32-py2.7.exe 
MySQL-python-1.2.3.win-amd64-py2.7.exe

免费下载地址:http://yunpan.cn/cVnTc9iRsQR4m 访问密码 06fc

安装过程很简单不多说:

实例 1、取得 MYSQL 的版本

[python] view plain copy
 
  1. # -*- coding: UTF-8 -*-  
  2. #安装 MYSQL DB for python  
  3. import MySQLdb as mdb  
  4. con = None  
  5. try:  
  6.     #连接 mysql 的方法: connect('ip','user','password','dbname')  
  7.     con = mdb.connect('localhost''root','root''test');  
  8.   
  9.     #所有的查询,都在连接 con 的一个模块 cursor 上面运行的  
  10.     cur = con.cursor()  
  11.   
  12.     #执行一个查询  
  13.     cur.execute("SELECT VERSION()")  
  14.     #取得上个查询的结果,是单个结果  
  15.   
  16.     data = cur.fetchone()  
  17.     print "Database version : %s " % data  
  18. finally:  
  19.     if con:  
  20.         #无论如何,连接记得关闭  
  21.         con.close()  

实例 2、创建一个表并且插入数据

[python] view plain copy
 
  1. import MySQLdb as mdb  
  2. import sys  
  3.   
  4. #将 con 设定为全局连接  
  5. con = mdb.connect('localhost''root''root''test');  
  6. with con:  
  7.   
  8. #获取连接的 cursor,只有获取了 cursor,我们才能进行各种操作  
  9. cur = con.cursor()  
  10.   
  11. #创建一个数据表 writers(id,name)  
  12. cur.execute("CREATE TABLE IF NOT EXISTS \  
  13. Writers(Id INT PRIMARY KEY AUTO_INCREMENT, Name VARCHAR(25))")  
  14.   
  15. #以下插入了 5 条数据  
  16. cur.execute("INSERT INTO Writers(Name) VALUES('Jack London')")  
  17. cur.execute("INSERT INTO Writers(Name) VALUES('Honore de Balzac')")  
  18. cur.execute("INSERT INTO Writers(Name) VALUES('Lion Feuchtwanger')")  
  19. cur.execute("INSERT INTO Writers(Name) VALUES('Emile Zola')")  
  20. cur.execute("INSERT INTO Writers(Name) VALUES('Truman Capote')")  

实例 3、 python 使用 slect 获取 mysql 的数据并遍历

[python] view plain copy
 
  1. import MySQLdb as mdb  
  2. import sys  
  3.   
  4. #连接 mysql,获取连接的对象  
  5. con = mdb.connect('localhost''root''root''test');  
  6. with con:  
  7.   
  8. #仍然是,第一步要获取连接的 cursor 对象,用于执行查询  
  9. cur = con.cursor()  
  10.   
  11. #类似于其他语言的 query 函数, execute 是 python 中的执行查询函数  
  12. cur.execute("SELECT * FROM Writers")  
  13.   
  14. #使用 fetchall 函数,将结果集(多维元组)存入 rows 里面  
  15. rows = cur.fetchall()  
  16.   
  17. #依次遍历结果集,发现每个元素,就是表中的一条记录,用一个元组来显示  
  18. for row in rows:  
  19. print row  

运行结果:

[python] view plain copy
 
  1. (1L, ‘Jack London’)  
  2. (2L, ‘Honore de Balzac’)  
  3. (3L, ‘Lion Feuchtwanger’)  
  4. (4L, ‘Emile Zola’)  
  5. (5L, ‘Truman Capote’)  

上面的代码,用来将所有的结果取出,不过打印的时候是每行一个元祖打印,现在我们使用方法,取出其中的单个数据:

[python] view plain copy
 
  1. import MySQLdb as mdb  
  2. import sys  
  3.   
  4. #获取 mysql 的链接对象  
  5. con = mdb.connect('localhost''root''root''test');  
  6. with con:  
  7. #获取执行查询的对象  
  8. cur = con.cursor()  
  9. #执行那个查询,这里用的是 select 语句  
  10. cur.execute("SELECT * FROM Writers")  
  11. #使用 cur.rowcount 获取结果集的条数  
  12. numrows = int(cur.rowcount)  
  13. #循环 numrows 次,每次取出一行数据  
  14. for i in range(numrows):  
  15. #每次取出一行,放到 row 中,这是一个元组(id,name)  
  16. row = cur.fetchone()  
  17. #直接输出两个元素  
  18. print row[0], row[1]  

运行结果:

[python] view plain copy
 
  1. 1 Jack London  
  2. 2 Honore de Balzac  
  3. 3 Lion Feuchtwanger  
  4. 4 Emile Zola  
  5. 5 Truman Capote  

实例 4、使用字典 cursor 取得结果集(可以使用表字段名字访问值)

[python] view plain copy
 
  1. import MySQLdb as mdb  
  2. import sys  
  3. #获得 mysql 查询的链接对象  
  4. con = mdb.connect('localhost''root''root''test')  
  5. with con:  
  6. #获取连接上的字典 cursor,注意获取的方法,  
  7. #每一个 cursor 其实都是 cursor 的子类  
  8. cur = con.cursor(mdb.cursors.DictCursor)  
  9. #执行语句不变  
  10. cur.execute("SELECT * FROM Writers")  
  11. #获取数据方法不变  
  12. rows = cur.fetchall()  
  13. #遍历数据也不变(比上一个更直接一点)  
  14. for row in rows:  
  15. #这里,可以使用键值对的方法,由键名字来获取数据  
  16. print "%s %s" % (row["Id"], row["Name"])  

实例 5、获取单个表的字段名和信息的方法

[python] view plain copy
 
  1. import MySQLdb as mdb  
  2. import sys  
  3. #获取数据库的链接对象  
  4. con = mdb.connect('localhost''root''root''test')  
  5. with con:  
  6. #获取普通的查询 cursor  
  7. cur = con.cursor()  
  8. cur.execute("SELECT * FROM Writers")  
  9. rows = cur.fetchall()  
  10. #获取连接对象的描述信息  
  11. desc = cur.description  
  12. print 'cur.description:',desc  
  13. #打印表头,就是字段名字  
  14. print "%s %3s" % (desc[0][0], desc[1][0])  
  15. for row in rows:  
  16. #打印结果  
  17. print "%2s %3s" % row  

运行结果:

[python] view plain copy
 
  1. cur.description: ((‘Id’, 31111100), (‘Name’, 25317252501))  
  2. Id Name  
  3. 1 Jack London  
  4. 2 Honore de Balzac  
  5. 3 Lion Feuchtwanger  
  6. 4 Emile Zola  
  7. 5 Truman Capote  

实例 6、使用 Prepared statements 执行查询(更安全方便)

[python] view plain copy
 
  1. import MySQLdb as mdb  
  2. import sys  
  3.   
  4. con = mdb.connect('localhost''root''root''test')  
  5. with con:  
  6. cur = con.cursor()  
  7. #我们看到,这里可以通过写一个可以组装的 sql 语句来进行  
  8. cur.execute("UPDATE Writers SET Name = %s WHERE Id = %s",  
  9. ("Guy de Maupasant""4"))  
  10. #使用 cur.rowcount 获取影响了多少行  
  11. print "Number of rows updated: %d" % cur.rowcount  
  12.   
  13. 结果:  
  14. Number of rows updated: 1  

实例 7、把图片用二进制存入 MYSQL

有人喜欢把图片存入 MYSQL(这种做法貌似很少吧),我看大部分的程序,图片都是存放在服务器上的文件,数据库中存的只是图片的地址而已,不过 MYSQL 是支持把图片存入数据库的,也相应的有一个专门的字段 BLOB (Binary Large Object),即较大的二进制对象字段,请看如下程序,注意测试图片自己随便找一个,地址要正确: 
首先,在数据库中创建一个表,用于存放图片:

[python] view plain copy
 
  1. CREATE TABLE Images(Id INT PRIMARY KEY AUTO_INCREMENT, Data MEDIUMBLOB);  

然后运行如下 PYTHON 代码进行:

[python] view plain copy
 
  1. import MySQLdb as mdb  
  2. import sys  
  3.   
  4. try:  
  5. #用读文件模式打开图片  
  6. fin = open("../web.jpg")  
  7. #将文本读入 img 对象中  
  8. img = fin.read()  
  9. #关闭文件  
  10. 来源:疯狂的蚂蚁的博客 www.crazyant.net 总结和整理  
  11. fin.close()  
  12. except IOError, e:  
  13. #如果出错,打印错误信息  
  14. print "Error %d: %s" % (e.args[0],e.args[1])  
  15. sys.exit(1)  
  16. try:  
  17. #链接 mysql,获取对象  
  18. conn = mdb.connect(host='localhost',user='root',passwd='root',  
  19. db='test')  
  20. #获取执行 cursor  
  21. cursor = conn.cursor()  
  22. #直接将数据作为字符串,插入数据库  
  23. cursor.execute("INSERT INTO Images SET Data='%s'" %  
  24. mdb.escape_string(img))  
  25. #提交数据  
  26. conn.commit()  
  27. #提交之后,再关闭 cursor 和链接  
  28. cursor.close()  
  29. conn.close()  
  30. except mdb.Error, e:  
  31. #若出现异常,打印信息  
  32. print "Error %d: %s" % (e.args[0],e.args[1])  
  33. sys.exit(1)  

实例 8、从数据库中把图片读出来

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

实例 9、使用 Transaction 即事务(手动提交,自动回滚)

[python] view plain copy
 
  1. import MySQLdb as mdb  
  2. import sys  
  3.   
  4. try:  
  5. #连接 mysql,获取连接的对象  
  6. conn = mdb.connect('localhost''root''root''test');  
  7. cursor = conn.cursor()  
  8. #如果某个数据库支持事务,会自动开启  
  9. #这里用的是 MYSQL,所以会自动开启事务(若是 MYISM 引擎则不会)  
  10. cursor.execute("UPDATE Writers SET Name = %s WHERE Id = %s",  
  11. ("Leo Tolstoy""1"))  
  12. cursor.execute("UPDATE Writers SET Name = %s WHERE Id = %s",  
  13. ("Boris Pasternak""2"))  
  14. cursor.execute("UPDATE Writer SET Name = %s WHERE Id = %s",  
  15. ("Leonid Leonov""3"))  
  16. #事务的特性 1、原子性的手动提交  
  17. conn.commit()  
  18. cursor.close()  
  19. conn.close()  
  20. except mdb.Error, e:  
  21. #如果出现了错误,那么可以回滚,就是上面的三条语句要么执行,要么都不执行  
  22. conn.rollback()  
  23. 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数据库实例详解【安装、连接、增删改查等】

    Python操作MySQL数据库是一种常见的任务,特别是在开发Web应用或者需要存储和处理数据的系统中。本篇文章将详细阐述如何使用Python与MySQL进行交互,包括安装MySQL库、建立连接、数据库和表的操作以及数据的增删改查...

    Python操作MySQL数据库9个实用实例

    在Windows平台上安装mysql模块用于Python开发 ...实例 1、取得 MYSQL 的版本 # -*- coding: UTF-8 -*- #安装 MYSQL DB for python import MySQLdb as mdb con = None try: #连接 mysql 的方法: connect('ip','user'

    Python访问MySQL数据库

    摘 要: 讲解了应用 Python 如何访问 MySQL 数据库。首先介绍了 Python、MySQL,然后讲解 MySQL 数据库访问模块,并通过一个实例来说明应用该模块来访问 MySQL 数据库,最后总结了用 Python 访问 MySQL 数据库的优点

    基于Python的MYSQL数据库访问技术.pdf

    本文将深入探讨如何使用Python语言访问MySQL数据库,通过实例演示如何在Eclipse集成开发环境中通过Python-MySQLconnector实现数据库的增、删、改、查操作。 首先,让我们了解Python DB-API的相关知识。在引入DB-API...

    完整版 Python高级开发课程 高级教程 06 Python操作MySQL数据库.pptx

    在本课程"Python高级开发课程 高级教程 06 Python操作MySQL数据库"中,我们将深入探讨如何使用Python与MySQL数据库进行交互。Python是广泛应用于数据处理和数据分析的语言,而MySQL则是一种流行的开源关系型数据库...

    python操作mysql数据库的9个实例共11页.pdf

    Python操作MySQL数据库是一种常见的数据交互方式,特别是在web开发中,Python的灵活性和MySQL的强大存储功能相结合,能够构建高效的数据处理系统。以下是对标题和描述中所述知识点的详细讲解: 1. **Python MySQL库...

    Python操作Mysql实例教程手册.pdf

    这篇“Python操作MySQL实例教程手册”将深入探讨如何通过Python进行MySQL数据库的操作。 首先,你需要了解Python的数据库接口标准——DB-API(PEP 249)。Python的DB-API提供了一个统一的接口,用于与各种不同的...

    Python操作Mysql实例代码教程.pdf

    Python操作Mysql实例代码教程.pdf

    Python访问MySQL数据库.pdf

    首先,作者概述了Python语言及其特点,接着介绍了MySQL数据库的访问模块,并通过实例展示了如何利用该模块操作MySQL数据库,最后总结了使用Python进行数据库访问的优势。 Python是一种由Guido van Rossum于1989年底...

    完整版 Python高级开发课程 高级教程 06 Python操作MySQL数据库.rar

    在“完整版 Python高级开发课程 高级教程 06 Python操作MySQL数据库.pptx”文件中,可能详细地介绍了这些概念,并通过实例展示了如何在Python中实现它们。学习这个教程将帮助你更好地理解如何利用Python高效地管理和...

    Python的MySQL数据库操作.docx

    ### Python的MySQL数据库操作知识点详解 #### 一、Python与MySQL数据库交互流程...以上就是关于Python操作MySQL数据库的基础知识点及其具体应用实例。对于初学者来说,这些知识点足够完成大部分基本的数据库操作任务。

    Python操作Mysql实例教程手册

    在本篇《Python操作Mysql实例教程手册》中,介绍了如何使用Python来操作MySQL数据库,涵盖了一系列基础和高级操作。包括执行SQL语句、获取结果集、遍历结果集、获取特定字段、获取表字段名、将图片插入数据库、执行...

    python3操作mysql实例源码

    本实例源码是针对初学者设计的,旨在帮助他们理解和掌握如何使用Python3操作MySQL数据库,实现增删改查等基本功能。 首先,我们来看`conn.py`文件,这是连接MySQL数据库的关键部分。在这个文件中,通常会包含使用`...

    Python操作Mysql实例教程手册高清完整PDF版

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

    Python操作数据库和实现mysql数据库连接池

    在本主题中,我们将深入探讨如何使用Python操作MySQL数据库以及如何实现数据库连接池。 首先,Python中常用的数据库操作库是`pymysql`和`mysql-connector-python`,它们提供了对MySQL数据库的接口。`pymysql`是...

    python3连接MySQL数据库实例详解

    本文实例为大家分享了python3连接MySQL数据库的具体代码,供大家参考,具体内容如下 #python3连接MySQL实例 import pymysql """导入连接MySQL需要的包,没有安装pymysql需要先安装 使用命令行切换到python的安装...

    python操作mysql教程与实例代码-PDF

    本文档详细介绍了使用Python语言通过MySQL数据库进行各种操作的教程和实例代码。内容包括连接MySQL数据库、执行SQL语句、获取结果集、遍历结果集、获取指定字段、获取表字段名、将图片插入数据库、执行事务等。实例...

Global site tag (gtag.js) - Google Analytics