Python操作MySQL數(shù)據(jù)庫的三種方法總結(jié)
1. MySQLdb 的使用
(1) 什么是MySQLdb?
MySQLdb 是用于 Python 連接 MySQL 數(shù)據(jù)庫的接口,它實(shí)現(xiàn)了 Python 數(shù)據(jù)庫 API 規(guī)范 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服務(wù)器...')
# 打開數(shù)據(jù)庫連接
# 用戶名:hp, 密碼:Hp12345.,用戶名和密碼需要改成你自己的mysql用戶名和密碼,并且要創(chuàng)建數(shù)據(jù)庫TESTDB,并在TESTDB數(shù)據(jù)庫中創(chuàng)建好表Student
db = MySQLdb.connect("localhost","hp","Hp12345.","TESTDB")
print('連接上了!')
return db
def createtable(db):
# 使用cursor()方法獲取操作游標(biāo)
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 )"""
# 創(chuàng)建Sutdent表
cursor.execute(sql)
def insertdb(db):
# 使用cursor()方法獲取操作游標(biāo)
cursor = db.cursor()
# SQL 插入語句
sql = """INSERT INTO Student
VALUES ('001', 'CZQ', 70),
('002', 'LHQ', 80),
('003', 'MQ', 90),
('004', 'WH', 80),
('005', 'HP', 70),
('006', 'YF', 66),
('007', 'TEST', 100)"""
#sql = "INSERT INTO Student(ID, Name, Grade) \
# VALUES ('%s', '%s', '%d')" % \
# ('001', 'HP', 60)
try:
# 執(zhí)行sql語句
cursor.execute(sql)
# 提交到數(shù)據(jù)庫執(zhí)行
db.commit()
except:
# Rollback in case there is any error
print '插入數(shù)據(jù)失敗!'
db.rollback()
def querydb(db):
# 使用cursor()方法獲取操作游標(biāo)
cursor = db.cursor()
# SQL 查詢語句
#sql = "SELECT * FROM Student \
# WHERE Grade > '%d'" % (80)
sql = "SELECT * FROM Student"
try:
# 執(zhí)行SQL語句
cursor.execute(sql)
# 獲取所有記錄列表
results = cursor.fetchall()
for row in results:
ID = row[0]
Name = row[1]
Grade = row[2]
# 打印結(jié)果
print "ID: %s, Name: %s, Grade: %d" % \
(ID, Name, Grade)
except:
print "Error: unable to fecth data"
def deletedb(db):
# 使用cursor()方法獲取操作游標(biāo)
cursor = db.cursor()
# SQL 刪除語句
sql = "DELETE FROM Student WHERE Grade = '%d'" % (100)
try:
# 執(zhí)行SQL語句
cursor.execute(sql)
# 提交修改
db.commit()
except:
print '刪除數(shù)據(jù)失敗!'
# 發(fā)生錯誤時回滾
db.rollback()
def updatedb(db):
# 使用cursor()方法獲取操作游標(biāo)
cursor = db.cursor()
# SQL 更新語句
sql = "UPDATE Student SET Grade = Grade + 3 WHERE ID = '%s'" % ('003')
try:
# 執(zhí)行SQL語句
cursor.execute(sql)
# 提交到數(shù)據(jù)庫執(zhí)行
db.commit()
except:
print '更新數(shù)據(jù)失敗!'
# 發(fā)生錯誤時回滾
db.rollback()
def closedb(db):
db.close()
def main():
db = connectdb() # 連接MySQL數(shù)據(jù)庫
createtable(db) # 創(chuàng)建表
insertdb(db) # 插入數(shù)據(jù)
print '\n插入數(shù)據(jù)后:'
querydb(db)
deletedb(db) # 刪除數(shù)據(jù)
print '\n刪除數(shù)據(jù)后:'
querydb(db)
updatedb(db) # 更新數(shù)據(jù)
print '\n更新數(shù)據(jù)后:'
querydb(db)
closedb(db) # 關(guān)閉數(shù)據(jù)庫
if __name__ == '__main__':
main()
運(yùn)行結(jié)果:

2. PyMySQL 的使用
(1) 什么是 PyMySQL?
PyMySQL 是 Python 中用于連接 MySQL 服務(wù)器的一個庫,它遵循 Python 數(shù)據(jù)庫 API 規(guī)范 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服務(wù)器...')
# 打開數(shù)據(jù)庫連接
# 用戶名:hp, 密碼:Hp12345.,用戶名和密碼需要改成你自己的mysql用戶名和密碼,并且要創(chuàng)建數(shù)據(jù)庫TESTDB,并在TESTDB數(shù)據(jù)庫中創(chuàng)建好表Student
db = pymysql.connect("localhost","hp","Hp12345.","TESTDB")
print('連接上了!')
return db
def createtable(db):
# 使用cursor()方法獲取操作游標(biāo)
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 )"""
# 創(chuàng)建Sutdent表
cursor.execute(sql)
def insertdb(db):
# 使用cursor()方法獲取操作游標(biāo)
cursor = db.cursor()
# SQL 插入語句
sql = """INSERT INTO Student
VALUES ('001', 'CZQ', 70),
('002', 'LHQ', 80),
('003', 'MQ', 90),
('004', 'WH', 80),
('005', 'HP', 70),
('006', 'YF', 66),
('007', 'TEST', 100)"""
#sql = "INSERT INTO Student(ID, Name, Grade) \
# VALUES ('%s', '%s', '%d')" % \
# ('001', 'HP', 60)
try:
# 執(zhí)行sql語句
cursor.execute(sql)
# 提交到數(shù)據(jù)庫執(zhí)行
db.commit()
except:
# Rollback in case there is any error
print '插入數(shù)據(jù)失敗!'
db.rollback()
def querydb(db):
# 使用cursor()方法獲取操作游標(biāo)
cursor = db.cursor()
# SQL 查詢語句
#sql = "SELECT * FROM Student \
# WHERE Grade > '%d'" % (80)
sql = "SELECT * FROM Student"
try:
# 執(zhí)行SQL語句
cursor.execute(sql)
# 獲取所有記錄列表
results = cursor.fetchall()
for row in results:
ID = row[0]
Name = row[1]
Grade = row[2]
# 打印結(jié)果
print "ID: %s, Name: %s, Grade: %d" % \
(ID, Name, Grade)
except:
print "Error: unable to fecth data"
def deletedb(db):
# 使用cursor()方法獲取操作游標(biāo)
cursor = db.cursor()
# SQL 刪除語句
sql = "DELETE FROM Student WHERE Grade = '%d'" % (100)
try:
# 執(zhí)行SQL語句
cursor.execute(sql)
# 提交修改
db.commit()
except:
print '刪除數(shù)據(jù)失敗!'
# 發(fā)生錯誤時回滾
db.rollback()
def updatedb(db):
# 使用cursor()方法獲取操作游標(biāo)
cursor = db.cursor()
# SQL 更新語句
sql = "UPDATE Student SET Grade = Grade + 3 WHERE ID = '%s'" % ('003')
try:
# 執(zhí)行SQL語句
cursor.execute(sql)
# 提交到數(shù)據(jù)庫執(zhí)行
db.commit()
except:
print '更新數(shù)據(jù)失敗!'
# 發(fā)生錯誤時回滾
db.rollback()
def closedb(db):
db.close()
def main():
db = connectdb() # 連接MySQL數(shù)據(jù)庫
createtable(db) # 創(chuàng)建表
insertdb(db) # 插入數(shù)據(jù)
print '\n插入數(shù)據(jù)后:'
querydb(db)
deletedb(db) # 刪除數(shù)據(jù)
print '\n刪除數(shù)據(jù)后:'
querydb(db)
updatedb(db) # 更新數(shù)據(jù)
print '\n更新數(shù)據(jù)后:'
querydb(db)
closedb(db) # 關(guān)閉數(shù)據(jù)庫
if __name__ == '__main__':
main()
運(yùn)行結(jié)果:

3. mysql.connector 的使用
(1) 什么是 mysql.connector?
由于 MySQL 服務(wù)器以獨(dú)立的進(jìn)程運(yùn)行,并通過網(wǎng)絡(luò)對外服務(wù),所以,需要支持 Python 的 MySQL 驅(qū)動來連接到 MySQL 服務(wù)器。
目前,有兩個 MySQL 驅(qū)動:
mysql-connector-python:是 MySQL 官方的純 Python 驅(qū)動;
MySQL-python :是封裝了 MySQL C驅(qū)動的 Python 驅(qū)動。
(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服務(wù)器...')
# 打開數(shù)據(jù)庫連接
# 用戶名:hp, 密碼:Hp12345.,用戶名和密碼需要改成你自己的mysql用戶名和密碼,并且要創(chuàng)建數(shù)據(jù)庫TESTDB,并在TESTDB數(shù)據(jù)庫中創(chuàng)建好表Student
db = mysql.connector.connect(user="hp", passwd="Hp12345.", database="TESTDB", use_unicode=True)
print('連接上了!')
return db
def createtable(db):
# 使用cursor()方法獲取操作游標(biāo)
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 )"""
# 創(chuàng)建Sutdent表
cursor.execute(sql)
def insertdb(db):
# 使用cursor()方法獲取操作游標(biāo)
cursor = db.cursor()
# SQL 插入語句
sql = """INSERT INTO Student
VALUES ('001', 'CZQ', 70),
('002', 'LHQ', 80),
('003', 'MQ', 90),
('004', 'WH', 80),
('005', 'HP', 70),
('006', 'YF', 66),
('007', 'TEST', 100)"""
#sql = "INSERT INTO Student(ID, Name, Grade) \
# VALUES ('%s', '%s', '%d')" % \
# ('001', 'HP', 60)
try:
# 執(zhí)行sql語句
cursor.execute(sql)
# 提交到數(shù)據(jù)庫執(zhí)行
db.commit()
except:
# Rollback in case there is any error
print '插入數(shù)據(jù)失敗!'
db.rollback()
def querydb(db):
# 使用cursor()方法獲取操作游標(biāo)
cursor = db.cursor()
# SQL 查詢語句
#sql = "SELECT * FROM Student \
# WHERE Grade > '%d'" % (80)
sql = "SELECT * FROM Student"
try:
# 執(zhí)行SQL語句
cursor.execute(sql)
# 獲取所有記錄列表
results = cursor.fetchall()
for row in results:
ID = row[0]
Name = row[1]
Grade = row[2]
# 打印結(jié)果
print "ID: %s, Name: %s, Grade: %d" % \
(ID, Name, Grade)
except:
print "Error: unable to fecth data"
def deletedb(db):
# 使用cursor()方法獲取操作游標(biāo)
cursor = db.cursor()
# SQL 刪除語句
sql = "DELETE FROM Student WHERE Grade = '%d'" % (100)
try:
# 執(zhí)行SQL語句
cursor.execute(sql)
# 提交修改
db.commit()
except:
print '刪除數(shù)據(jù)失敗!'
# 發(fā)生錯誤時回滾
db.rollback()
def updatedb(db):
# 使用cursor()方法獲取操作游標(biāo)
cursor = db.cursor()
# SQL 更新語句
sql = "UPDATE Student SET Grade = Grade + 3 WHERE ID = '%s'" % ('003')
try:
# 執(zhí)行SQL語句
cursor.execute(sql)
# 提交到數(shù)據(jù)庫執(zhí)行
db.commit()
except:
print '更新數(shù)據(jù)失敗!'
# 發(fā)生錯誤時回滾
db.rollback()
def closedb(db):
db.close()
def main():
db = connectdb() # 連接MySQL數(shù)據(jù)庫
createtable(db) # 創(chuàng)建表
insertdb(db) # 插入數(shù)據(jù)
print '\n插入數(shù)據(jù)后:'
querydb(db)
deletedb(db) # 刪除數(shù)據(jù)
print '\n刪除數(shù)據(jù)后:'
querydb(db)
updatedb(db) # 更新數(shù)據(jù)
print '\n更新數(shù)據(jù)后:'
querydb(db)
closedb(db) # 關(guān)閉數(shù)據(jù)庫
if __name__ == '__main__':
main()
運(yùn)行結(jié)果:

以上這篇Python操作MySQL數(shù)據(jù)庫的三種方法總結(jié)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Python返回數(shù)組/List長度的實(shí)例
今天小編就為大家分享一篇Python返回數(shù)組/List長度的實(shí)例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-06-06
Python使用Transformers實(shí)現(xiàn)機(jī)器翻譯功能
近年來,機(jī)器翻譯技術(shù)飛速發(fā)展,從傳統(tǒng)的基于規(guī)則的翻譯到統(tǒng)計機(jī)器翻譯,再到如今流行的神經(jīng)網(wǎng)絡(luò)翻譯模型,尤其是基于Transformer架構(gòu)的模型,翻譯效果已經(jīng)有了質(zhì)的飛躍,本文將詳細(xì)介紹如何使用Transformers庫來實(shí)現(xiàn)一個機(jī)器翻譯模型,需要的朋友可以參考下2024-11-11
Python常用標(biāo)準(zhǔn)庫詳解(pickle序列化和JSON序列化)
這篇文章主要介紹了Python常用標(biāo)準(zhǔn)庫,主要包括pickle序列化和JSON序列化模塊,通過使用場景分析給大家介紹的非常詳細(xì),需要的朋友可以參考下2022-05-05

