Python調用Mysqldb完成MySql的CRUD操作

來源:互聯網
上載者:User

標籤:調用   使用者   tab   win10   int   相關   utf-8   roo   ror   

[硬體環境]

Win10 64位

[軟體環境]

Python版本:2.7.3

IDE:JetBrains PyCharm 2016.3.2

Python庫:

1.1) MySQL-python-1.2.4b4.win32-py2.7.exe

[搭建過程]

OpenCV Python庫:

1. 直接EXE檔案安裝

[相關代碼]

#!/usr/bin/python# -*- coding: UTF-8 -*-import MySQLdb# 您已經建立了資料庫 TESTDB.# 在TESTDB資料庫中您已經建立了表 EMPLOYEE# EMPLOYEE表欄位為 FIRST_NAME, LAST_NAME, AGE, SEX 和 INCOME。# 串連資料庫TESTDB使用的使用者名稱為 "testuser" ,密碼為 "test123",你可以可以自己設定或者直接使用root使用者名稱及其密碼,Mysql資料庫使用者授權請使用Grant命令。# 在你的機子上已經安裝了 Python MySQLdb 模組。# 開啟資料庫連接db = MySQLdb.connect("localhost", "testuser", "test123", "TESTDB" )# 使用cursor()方法擷取操作遊標cursor = db.cursor()# 使用execute方法執行SQL語句cursor.execute("SELECT VERSION()")# 使用 fetchone() 方法擷取一條資料庫。data = cursor.fetchone()print "Database version : %s " % data# 關閉資料庫連接db.close()################################################ 建立資料庫表 ##################################################### 開啟資料庫連接db = MySQLdb.connect("localhost", "testuser", "test123", "TESTDB" )# 使用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()################################################ 資料庫插入 ##################################################### 開啟資料庫連接db = MySQLdb.connect("localhost", "testuser", "test123", "TESTDB" )# 使用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()################################################ 資料庫查詢 ##################################################### 開啟資料庫連接db = MySQLdb.connect("localhost", "testuser", "test123", "TESTDB" )# 使用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()################################################ 資料庫更新 ##################################################### 開啟資料庫連接db = MySQLdb.connect("localhost", "testuser", "test123", "TESTDB" )# 使用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()################################################ 資料庫刪除 ##################################################### 開啟資料庫連接db = MySQLdb.connect("localhost", "testuser", "test123", "TESTDB" )# 使用cursor()方法擷取操作遊標cursor = db.cursor()# SQL 刪除語句sql = "DELETE FROM EMPLOYEE WHERE AGE > ‘%d‘" % (20)try:   # 執行SQL語句   cursor.execute(sql)   # 提交修改   db.commit()except:   # 發生錯誤時復原   db.rollback()# 關閉串連db.close()

 

Python調用Mysqldb完成MySql的CRUD操作

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.