1. 程式人生 > 資料庫 >Python操作MySQL資料庫的三種方法總結

Python操作MySQL資料庫的三種方法總結

1. MySQLdb 的使用

(1) 什麼是MySQLdb?

MySQLdb 是用於 Python 連線 MySQL 資料庫的介面,它實現了 Python 資料庫 API 規範 V2.0,基於 MySQL C API 上建立的。

(2) 原始碼安裝 MySQLdb: https://pypi.python.org/pypi/MySQL-python

$ tar zxvf MySQL-python-*.tar.gz
$ cd MySQL-python-*
$ python setup.py build
$ python setup.py install

(3) MySQLdb 的使用:

#!/usr/bin/env python
# coding=utf-8

import MySQLdb

def connectdb():
 print('連線到mysql伺服器...')
 # 開啟資料庫連線
 # 使用者名稱:hp,密碼:Hp12345.,使用者名稱和密碼需要改成你自己的mysql使用者名稱和密碼,並且要建立資料庫TESTDB,並在TESTDB資料庫中建立好表Student
 db = MySQLdb.connect("localhost","hp","Hp12345.","TESTDB")
 print('連線上了!')
 return db

def createtable(db):
 # 使用cursor()方法獲取操作遊標 
 cursor = db.cursor()

 # 如果存在表Sutdent先刪除
 cursor.execute("DROP TABLE IF EXISTS Student")
 sql = """CREATE TABLE Student (
   ID CHAR(10) NOT NULL,Name CHAR(8),Grade INT )"""

 # 建立Sutdent表
 cursor.execute(sql)

def insertdb(db):
 # 使用cursor()方法獲取操作遊標 
 cursor = db.cursor()

 # SQL 插入語句
 sql = """INSERT INTO Student
   VALUES ('001','CZQ',70),('002','LHQ',80),('003','MQ',90),('004','WH',('005','HP',('006','YF',66),('007','TEST',100)"""

 #sql = "INSERT INTO Student(ID,Name,Grade) \
 # VALUES ('%s','%s','%d')" % \
 # ('001',60)
 try:
  # 執行sql語句
  cursor.execute(sql)
  # 提交到資料庫執行
  db.commit()
 except:
  # Rollback in case there is any error
  print '插入資料失敗!'
  db.rollback()

def querydb(db):
 # 使用cursor()方法獲取操作遊標 
 cursor = db.cursor()

 # SQL 查詢語句
 #sql = "SELECT * FROM Student \
 # WHERE Grade > '%d'" % (80)
 sql = "SELECT * FROM Student"
 try:
  # 執行SQL語句
  cursor.execute(sql)
  # 獲取所有記錄列表
  results = cursor.fetchall()
  for row in results:
   ID = row[0]
   Name = row[1]
   Grade = row[2]
   # 列印結果
   print "ID: %s,Name: %s,Grade: %d" % \
    (ID,Grade)
 except:
  print "Error: unable to fecth data"

def deletedb(db):
 # 使用cursor()方法獲取操作遊標 
 cursor = db.cursor()

 # SQL 刪除語句
 sql = "DELETE FROM Student WHERE Grade = '%d'" % (100)

 try:
  # 執行SQL語句
  cursor.execute(sql)
  # 提交修改
  db.commit()
 except:
  print '刪除資料失敗!'
  # 發生錯誤時回滾
  db.rollback()

def updatedb(db):
 # 使用cursor()方法獲取操作遊標 
 cursor = db.cursor()

 # SQL 更新語句
 sql = "UPDATE Student SET Grade = Grade + 3 WHERE ID = '%s'" % ('003')

 try:
  # 執行SQL語句
  cursor.execute(sql)
  # 提交到資料庫執行
  db.commit()
 except:
  print '更新資料失敗!'
  # 發生錯誤時回滾
  db.rollback()

def closedb(db):
 db.close()

def main():
 db = connectdb() # 連線MySQL資料庫

 createtable(db)  # 建立表
 insertdb(db)  # 插入資料
 print '\n插入資料後:'
 querydb(db) 
 deletedb(db)  # 刪除資料
 print '\n刪除資料後:'
 querydb(db)
 updatedb(db)  # 更新資料
 print '\n更新資料後:'
 querydb(db)

 closedb(db)   # 關閉資料庫

if __name__ == '__main__':
 main()

執行結果:

2. PyMySQL 的使用

(1) 什麼是 PyMySQL?

PyMySQL 是 Python 中用於連線 MySQL 伺服器的一個庫,它遵循 Python 資料庫 API 規範 V2.0,幷包含了 pure-Python MySQL 客戶端庫。

(2) 安裝 PyMysql:

pip install PyMysql

(3) 使用 PyMySQL:

#!/usr/bin/env python
# coding=utf-8

import pymysql

def connectdb():
 print('連線到mysql伺服器...')
 # 開啟資料庫連線
 # 使用者名稱:hp,使用者名稱和密碼需要改成你自己的mysql使用者名稱和密碼,並且要建立資料庫TESTDB,並在TESTDB資料庫中建立好表Student
 db = pymysql.connect("localhost",Grade)
 except:
  print "Error: unable to fecth data"

def deletedb(db):
 # 使用cursor()方法獲取操作遊標 
 cursor = db.cursor()

 # SQL 刪除語句
 sql = "DELETE FROM Student WHERE Grade = '%d'" % (100)

 try:
  # 執行SQL語句
  cursor.execute(sql)
  # 提交修改
  db.commit()
 except:
  print '刪除資料失敗!'
  # 發生錯誤時回滾
  db.rollback()

def updatedb(db):
 # 使用cursor()方法獲取操作遊標 
 cursor = db.cursor()

 # SQL 更新語句
 sql = "UPDATE Student SET Grade = Grade + 3 WHERE ID = '%s'" % ('003')

 try:
  # 執行SQL語句
  cursor.execute(sql)
  # 提交到資料庫執行
  db.commit()
 except:
  print '更新資料失敗!'
  # 發生錯誤時回滾
  db.rollback()

def closedb(db):
 db.close()

def main():
 db = connectdb() # 連線MySQL資料庫

 createtable(db)  # 建立表
 insertdb(db)  # 插入資料
 print '\n插入資料後:'
 querydb(db) 
 deletedb(db)  # 刪除資料
 print '\n刪除資料後:'
 querydb(db)
 updatedb(db)  # 更新資料
 print '\n更新資料後:'
 querydb(db)

 closedb(db)   # 關閉資料庫

if __name__ == '__main__':
 main()

執行結果:

3. mysql.connector 的使用

(1) 什麼是 mysql.connector?

由於 MySQL 伺服器以獨立的程序執行,並通過網路對外服務,所以,需要支援 Python 的 MySQL 驅動來連線到 MySQL 伺服器。

目前,有兩個 MySQL 驅動:

mysql-connector-python:是 MySQL 官方的純 Python 驅動;

MySQL-python :是封裝了 MySQL C驅動的 Python 驅動。

(2) 安裝 mysql.connector:

pip install mysql-connector-python
pip install MySQL-python

(3) 使用 mysql.connector:

#!/usr/bin/env python
# coding=utf-8

import mysql.connector

def connectdb():
 print('連線到mysql伺服器...')
 # 開啟資料庫連線
 # 使用者名稱:hp,使用者名稱和密碼需要改成你自己的mysql使用者名稱和密碼,並且要建立資料庫TESTDB,並在TESTDB資料庫中建立好表Student
 db = mysql.connector.connect(user="hp",passwd="Hp12345.",database="TESTDB",use_unicode=True)
 print('連線上了!')
 return db

def createtable(db):
 # 使用cursor()方法獲取操作遊標 
 cursor = db.cursor()

 # 如果存在表Sutdent先刪除
 cursor.execute("DROP TABLE IF EXISTS Student")
 sql = """CREATE TABLE Student (
   ID CHAR(10) NOT NULL,Grade)
 except:
  print "Error: unable to fecth data"

def deletedb(db):
 # 使用cursor()方法獲取操作遊標 
 cursor = db.cursor()

 # SQL 刪除語句
 sql = "DELETE FROM Student WHERE Grade = '%d'" % (100)

 try:
  # 執行SQL語句
  cursor.execute(sql)
  # 提交修改
  db.commit()
 except:
  print '刪除資料失敗!'
  # 發生錯誤時回滾
  db.rollback()

def updatedb(db):
 # 使用cursor()方法獲取操作遊標 
 cursor = db.cursor()

 # SQL 更新語句
 sql = "UPDATE Student SET Grade = Grade + 3 WHERE ID = '%s'" % ('003')

 try:
  # 執行SQL語句
  cursor.execute(sql)
  # 提交到資料庫執行
  db.commit()
 except:
  print '更新資料失敗!'
  # 發生錯誤時回滾
  db.rollback()

def closedb(db):
 db.close()

def main():
 db = connectdb() # 連線MySQL資料庫

 createtable(db)  # 建立表
 insertdb(db)  # 插入資料
 print '\n插入資料後:'
 querydb(db) 
 deletedb(db)  # 刪除資料
 print '\n刪除資料後:'
 querydb(db)
 updatedb(db)  # 更新資料
 print '\n更新資料後:'
 querydb(db)

 closedb(db)   # 關閉資料庫

if __name__ == '__main__':
 main()

執行結果:

以上這篇Python操作MySQL資料庫的三種方法總結就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支援我們。