在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);

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

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)

实例 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 即事务(手动提交,自动回滚)

import MySQLdb as mdb

import sys

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 引擎,则都不会执行。

来自:http://blog.csdn.net/xlgen157387/article/details/45132807

mysql 操作xm_Python操作MySQL数据库实例详解相关推荐

  1. silverlight mysql_Silverlight中衔接MySQL数据库实例详解

    Silverlight中衔接MySQL数据库实例详解 日期:2010年5月25日 作者: 本文将重点讲述Silverlight中衔接MySQL数据库实例,这在RIA开发中比拟根底,但是也是比拟首要的内 ...

  2. 如何查看mysql备份的情况_MySQL数据库备份详解(示例代码)

    原文:MySQL数据库备份详解 对于任何数据库来说,备份都是非常重要的 数据库复制不能取代备份的作用 比如我们由于误操作,在主数据库上删除了一些数据,由于主从复制的时间很短,在发现时,从数据库上的数据 ...

  3. wps连接mysql数据库增删改查_Python操作MySQL数据库实例详解【安装、连接、增删改查等】...

    本文实例讲述了python操作MySQL数据库.分享给大家供大家参考,具体如下: 1.安装 通过Python连接MySQL数据库有很多库,这里使用官方推荐的MySQL Connector/Python ...

  4. mysql数据表操作_MySQL数据表基本操作实例详解

    本文实例讲述了MySQL数据表基本操作.分享给大家供大家参考,具体如下: 数据表的基本操作 1.主键约束要求主键列的数据唯一,并且不允许为空.主键能够唯一地识别表中的一条记录,可以结合外键来定义不同数 ...

  5. java MySQL表的约束与数据库设计 详解

    1.DQL 数据查询语言 在上一篇博文中,我们已经讲述了部分数据查询语句,在此我们再次对其进行补充. 1.1 排序 通过ORDAR BY 语句,可以将查询出来的结果进行排序.(排除只是一种现实的方式, ...

  6. python3连接mysql,python3连接MySQL数据库实例详解

    本文实例为大家分享了python3连接MySQL数据库的具体代码,供大家参考,具体内容如下 #python3连接MySQL实例 import pymysql """导入连 ...

  7. 怎么导入mysql示例_MySQL命令行导出导入数据库实例详解

    1,进入MysqL目录下的bin文件夹:cd MysqL中到bin文件夹的目录 如我输入的命令行:cd C:\Program Files\MysqL\MysqL Server 5.5\bin (或者直 ...

  8. thinkphp mysql limit_limit方法 - ThinkPHP5数据库实例详解 - php中文网手册

    limit方法 1.功能:限制查询结果集输出的数量limit方法常用在分页显示用,对于记录较多的数据表,限制每次输出数量,很有必要 2.源码:直接贴上,不再附图/** * 指定查询数量 * @acce ...

  9. MySQL中的sum函数用法实例详解

    今天分享一下mysql中的sum函数使用.该函数已经成为大家操作mysql数据库中时常用到的一个函数,这个函数统计满足条件行中指定列的和,想必肯定大家都知道了,本身就没什么讲头了,这篇文章主要是通过几 ...

最新文章

  1. 题目1251:序列分割(DFS+剪枝)
  2. 迷失只是暂时 2011-03-13
  3. python编辑程序模型_Python编程语言实行尽可能成熟、稳定的新管理模型
  4. golang 获取当天0点时间_golang使用webAssembly的方式
  5. 计算机组成原理试题 t4,计算机组成原理(四版)本科生试题库整理附答案
  6. 将json字符串转换成html,根据json字符串生成Html的一种方式
  7. C++中#includeXXX.h和#includeXXX.h的区别
  8. 安装Esxi6.5时出现 menu.c32:not a COM32R image 的处理方法
  9. 最新b站后端源码,仅学习使用,请勿用于商业用途,如拿去非法使用与本人无关!
  10. 三种 绘制奈奎斯特曲线 的方法
  11. linux测试dns配置文件,Linux系统中如何查看和修改DNS配置
  12. OpenCV实现图片锐化
  13. switch系统升级无法连接服务器失败,switch更新无法连接服务器(图文)
  14. 麋鹿微博工具箱 · 批量删除微博、设置仅自己可见、仅好友可见等
  15. password unchanged Authentication token manipulation error
  16. android+高仿视频录制,高仿微信视频录制, 涂鸦水印添加, 基于 ffmpeg 视频编辑
  17. Vue报错:Error in v-on handler: “ReferenceError: regeneratorRuntime is not defined“
  18. 无向图的关联矩阵JAVA_图的矩阵表示无向图及有向图的关联矩阵.doc
  19. CUDA流多处理器(stream multiprocessor,sm)和硬件流处理器(stream processor,sp)
  20. docker 基础知识分享ppt

热门文章

  1. NCH WavePad Mater for Mac(音乐编辑器)
  2. 使用Aruino Ethernet使ESP32具有以太网通讯能力
  3. vue 后台翻译_vue前端vue-i18n实现翻译功能
  4. 【ACM】杭电1178:Heritage from father 小心溢出!
  5. unity 创建Txt文件并写入数据
  6. cobaltstrike安装使用
  7. Mandala Coloring Book Game ver 1.2 - 曼陀羅著色遊戲U3D源碼
  8. 【Verilog基础】CDC跨时钟域问题,个人理解总结(下)(数据丢失、多路扇出、异步复位解决方案)
  9. 《笨方法学 Python 3》43.基本的面向对象分析和设计
  10. 写一个matlab程序,自己写的第一个matlab程序