python中MySQLdb模組用法執行個體

來源:互聯網
上載者:User

標籤:

篇文章主要介紹了python中MySQLdb模組用法,以執行個體形式詳細講述了MySQLdb模組針對MySQL資料庫的各種常見操作方法,非常具有實用價值,需要的朋友可以參考下

 




本文執行個體講述了python中MySQLdb模組用法。分享給大家供大家參考。具體用法分析如下:

MySQLdb其實有點像php或asp中串連資料庫的一個模式了,只是MySQLdb是針對mysql串連了介面,我們可以在python中串連MySQLdb來實現資料的各種操作。

python串連mysql的方案有oursql、PyMySQL、 myconnpy、MySQL Connector 等,不過本篇要說的確是另外一個類庫MySQLdb,MySQLdb 是用於Python連結Mysql資料庫的介面,它實現了 Python 資料庫 API 規範 V2.0,基於 MySQL C API 上建立的。可以從:https://pypi.python.org/pypi/MySQL-python 進行擷取和安裝,而且很多發行版的linux源裡都有該模組,可以直接通過源安裝。

一、資料庫連接

MySQLdb提供了connect方法用來和資料庫建立串連,接收數個參數,返回連線物件:


複製代碼 代碼如下:

conn=MySQLdb.connect(host="localhost",user="root",passwd="jb51",db="test",charset="utf8")

比較常用的參數包括:
host:資料庫主機名稱.預設是用本地主機
user:資料庫登陸名.預設是目前使用者
passwd:資料庫登陸的秘密.預設為空白
db:要使用的資料庫名.沒有預設值
port:MySQL服務使用的TCP連接埠.預設是3306
charset:資料庫編碼
更多關於參數的資訊可以查這裡 http://mysql-python.sourceforge.net/MySQLdb.html

然後,這個連線物件也提供了對事務操作的支援,標準的方法:
commit() 提交
rollback() 復原

看一個簡單的查詢樣本如下:


複製代碼 代碼如下:

#!/usr/bin/python
# encoding: utf-8
import MySQLdb
# 開啟資料庫連接
db = MySQLdb.connect("localhost","root","361way","test" )
# 使用cursor()方法擷取操作遊標
cursor = db.cursor()
# 使用execute方法執行SQL語句
cursor.execute("SELECT VERSION()")
# 使用 fetchone() 方法擷取一條資料庫。
data = cursor.fetchone()
print "Database version : %s " % data
# 關閉資料庫連接
db.close()

指令碼執行結果如下:
Database version : 5.5.40

二、cursor方法執行與傳回值

cursor方法提供兩類操作:1.執行命令,2.接收傳回值 。
cursor用來執行命令的方法


複製代碼 代碼如下:

//用來執行預存程序,接收的參數為預存程序名和參數列表,傳回值為受影響的行數
callproc(self, procname, args)
//執行單條sql語句,接收的參數為sql語句本身和使用的參數列表,傳回值為受影響的行數
execute(self, query, args)
//執行單挑sql語句,但是重複執行參數列表裡的參數,傳回值為受影響的行數
executemany(self, query, args)
//移動到下一個結果集
nextset(self)
cursor用來接收傳回值的方法
//接收全部的返回結果行.
fetchall(self)
//接收size條返回結果行.如果size的值大於返回的結果行的數量,則會返回cursor.arraysize條資料
fetchmany(self, size=None)
//返回一條結果行
fetchone(self)
//移動指標到某一行.如果mode=‘relative‘,則表示從當前所在行移動value條,如果mode=‘absolute‘,則表示從結果集的第一行移動value條
scroll(self, value, mode=‘relative‘)
//這是一個唯讀屬性,並返回執行execute()方法後影響的行數
rowcount

三、資料庫操作

1、建立database tables
如果資料庫連接存在我們可以使用execute()方法來為資料庫建立表,如下所示建立表EMPLOYEE:


複製代碼 代碼如下:

#!/usr/bin/python
# encoding: utf-8
import MySQLdb
# 開啟資料庫連接
db = MySQLdb.connect("localhost","root","361way","test" )
# 使用cursor()方法擷取操作遊標
cursor = db.cursor()
# 如果資料表已經存在使用 execute() 方法刪除表。
cursor.execute("DROP TABLE IF EXISTS EMPLOYEE")
# 建立資料表SQL語句
sql = """CREATE TABLE EMPLOYEE (
FIRST_NAME CHAR(20) NOT NULL,
LAST_NAME CHAR(20),
AGE INT,
SEX CHAR(1),
INCOME FLOAT )"""
cursor.execute(sql)
# 關閉資料庫連接
db.close()

2、資料庫插入操作

複製代碼 代碼如下:

#!/usr/bin/python
# encoding: utf-8
import MySQLdb
# 開啟資料庫連接
db = MySQLdb.connect("localhost","root","361way","test" )
# 使用cursor()方法擷取操作遊標
cursor = db.cursor()
# SQL 插入語句
sql = """INSERT INTO EMPLOYEE(FIRST_NAME,
LAST_NAME, AGE, SEX, INCOME)
VALUES (‘Mac‘, ‘Mohan‘, 20, ‘M‘, 2000)"""
try:
# 執行sql語句
cursor.execute(sql)
# 提交到資料庫執行
db.commit()
except:
# Rollback in case there is any error
db.rollback()
# 關閉資料庫連接
db.close()

這裡是一個單sql 執行的樣本,cursor.executemany的用法感興趣的讀者可以參看相關的aws主機資產管理系統樣本。
上例也可以寫成通過預留位置傳參的方式進行執行,如下:

複製代碼 代碼如下:

#!/usr/bin/python
# encoding: utf-8
import MySQLdb
# 開啟資料庫連接
db = MySQLdb.connect("localhost","testuser","test123","TESTDB" )
# 使用cursor()方法擷取操作遊標
cursor = db.cursor()
# SQL 插入語句
sql = "INSERT INTO EMPLOYEE(FIRST_NAME, \
LAST_NAME, AGE, SEX, INCOME) \
VALUES (‘%s‘, ‘%s‘, ‘%d‘, ‘%c‘, ‘%d‘ )" % \
(‘Mac‘, ‘Mohan‘, 20, ‘M‘, 2000)
try:
# 執行sql語句
cursor.execute(sql)
# 提交到資料庫執行
db.commit()
except:
# 發生錯誤時復原
db.rollback()
# 關閉資料庫連接
db.close()

也可以以變數的方式傳遞參數,如下:

複製代碼 代碼如下:

..................................
user_id = "test"
password = "password123"
con.execute(‘insert into Login values("%s", "%s")‘ % \
(user_id, password))
..................................

3、資料庫查詢操作
以查詢EMPLOYEE表中salary(工資)欄位大於1000的所有資料為例:

複製代碼 代碼如下:

#!/usr/bin/python
# encoding: utf-8
import MySQLdb
# 開啟資料庫連接
db = MySQLdb.connect("localhost","root","361way","test" )
# 使用cursor()方法擷取操作遊標
cursor = db.cursor()
# SQL 查詢語句
sql = "SELECT * FROM EMPLOYEE \
WHERE INCOME > ‘%d‘" % (1000)
try:
# 執行SQL語句
cursor.execute(sql)
# 擷取所有記錄列表
results = cursor.fetchall()
for row in results:
fname = row[0]
lname = row[1]
age = row[2]
sex = row[3]
income = row[4]
# 列印結果
print "fname=%s,lname=%s,age=%d,sex=%s,income=%d" % \
(fname, lname, age, sex, income )
except:
print "Error: unable to fecth data"
# 關閉資料庫連接
db.close()

以上指令碼執行結果如下:
fname=Mac, lname=Mohan, age=20, sex=M, income=2000

4、資料庫更新操作
更新操作用於更新資料表的的資料,以下執行個體將 test表中的 SEX 欄位全部修改為 ‘M‘,AGE 欄位遞增1:


複製代碼 代碼如下:

# encoding: utf-8
#!/usr/bin/python
import MySQLdb
# 開啟資料庫連接
db = MySQLdb.connect("localhost","root","361way","test" )
# 使用cursor()方法擷取操作遊標
cursor = db.cursor()
# SQL 更新語句
sql = "UPDATE EMPLOYEE SET AGE = AGE + 1
WHERE SEX = ‘%c‘" % (‘M‘)
try:
# 執行SQL語句
cursor.execute(sql)
# 提交到資料庫執行
db.commit()
except:
# 發生錯誤時復原
db.rollback()
# 關閉資料庫連接
db.close()

5、執行事務

事務機制可以確保資料一致性。
事務應該具有4個屬性:原子性、一致性、隔離性、持久性。這四個屬性通常稱為ACID特性。
① 原子性(atomicity)。一個事務是一個不可分割的工作單位,事務中包括的諸操作要麼都做,要麼都不做。
② 一致性(consistency)。事務必須是使資料庫從一個一致性狀態變到另一個一致性狀態。一致性與原子性是密切相關的。
③ 隔離性(isolation)。一個事務的執行不能被其他事務幹擾。即一個事務內部的操作及使用的資料對並發的其他事務是隔離的,並發執行的各個事務之間不能互相干擾。
④ 持久性(durability)。持久性也稱永久性(permanence),指一個事務一旦提交,它對資料庫中資料的改變就應該是永久性的。接下來的其他動作或故障不應該對其有任何影響。

Python DB API 2.0 的事務提供了兩個方法 commit 或 rollback。執行個體:


複製代碼 代碼如下:

# SQL刪除記錄語句
sql = "DELETE FROM EMPLOYEE WHERE AGE > ‘%d‘" % (20)
try:
# 執行SQL語句
cursor.execute(sql)
# 向資料庫提交
db.commit()
except:
# 發生錯誤時復原
db.rollback()

對於支援事務的資料庫, 在Python資料庫編程中,當遊標建立之時,就自動開始了一個隱形的資料庫事務。commit()方法遊標的所有更新操作,rollback()方法復原當前遊標的所有操作。每一個方法都開始了一個新的事務。

python中MySQLdb模組用法執行個體

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.