Python操作MySQL数据库实例

作者:北京诚信汇发物流有限公司  来源:www.cxhfwL.com  发布时间:2017-09-11 14:01:03
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

安装过程很简单不多说:

实例 1、取得 MYSQL 的版本 # -*- 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() 实例 2、创建一个表并且插入数据 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')) 实例 3、 python 使用 slect 获取 mysql 的数据并遍历 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 里面 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’)

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

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]

运行结果:

1 Jack London 2 Honore de Balzac 3 Lion Feuchtwanger 4 Emile Zola 5 Truman Capote 实例 4、使用字典 cursor 取得结果集(可以使用表字段名字访问值) 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]) 实例 5、获取单个表的字段名和信息的方法 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 执行查询(更安全方便) 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);

企业建站2800元起,携手武汉肥猫科技,做一个有见地的颜值派!更多优惠请戳:天门SEO http://tianmen.raoyu.net


上一篇:百度竞价推广怎么做 如何提升转换量
下一篇:最后一页