Python操作MySQL資料庫的三種方法總結
阿新 • • 發佈:2020-01-09
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資料庫的三種方法總結就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支援我們。