中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Python操作MySQL數據庫的三種方法總結

發布時間:2020-09-04 20:01:34 來源:腳本之家 閱讀:242 作者:HP的博客 欄目:開發技術

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', 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:
  # 執行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, Name, 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數據庫的三種方法總結

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, 密碼:Hp12345.,用戶名和密碼需要改成你自己的mysql用戶名和密碼,并且要創建數據庫TESTDB,并在TESTDB數據庫中創建好表Student
 db = pymysql.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', 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:
  # 執行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, Name, 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數據庫的三種方法總結

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, 密碼:Hp12345.,用戶名和密碼需要改成你自己的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,
   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', 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:
  # 執行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, Name, 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數據庫的三種方法總結

以上這篇Python操作MySQL數據庫的三種方法總結就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

大理市| 汨罗市| 海阳市| 克拉玛依市| 师宗县| 合作市| 伊金霍洛旗| 平江县| 罗田县| 思茅市| 太原市| 南皮县| 闽清县| 天台县| 离岛区| 通江县| 莲花县| 阿瓦提县| 东方市| 郸城县| 栾城县| 会理县| 定兴县| 靖宇县| 长沙市| 灵川县| 宜良县| 岳池县| 达尔| 承德市| 保亭| 视频| 孟连| 曲靖市| 五华县| 桃江县| 农安县| 密云县| 金川县| 晋江市| 英超|