python操作mysql实战_Python操作MySQL数据库9个实用实例

本文通过9个实例详细介绍了如何使用Python连接并操作MySQL数据库,包括连接数据库、创建表、插入数据、查询数据、使用字典游标、获取字段信息、预编译语句、存储二进制数据以及事务处理等。
摘要由CSDN通过智能技术生成

实例 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

实例

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

实例 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

实例

7、把图片用二进制存入

MYSQL

import

MySQLdb as mdb

import

sys

try:

#用读文件模式打开图片

fin =

open("../web.jpg")

#将文本读入

img 对象中

img =

fin.read()

#关闭文件

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])

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值