python專題-Mysql資料庫(python3._+ PyMysql)

来源:http://www.cnblogs.com/cmt110/archive/2017/09/01/7464929.html
-Advertisement-
Play Games

之前寫過一篇 Python使用MySQL資料庫的博客,主要使用的是Python2和MySQLdb驅動。 python使用mysql資料庫 Python2 > Python3 MySQLdb --> PyMySQL 一,安裝PyMySQL Python是編程語言,MySQL是資料庫,它們是兩種不同的技 ...


  之前寫過一篇 Python使用MySQL資料庫的博客,主要使用的是Python2MySQLdb驅動。

  python使用mysql資料庫

  • Python2 ---> Python3
  • MySQLdb --> PyMySQL

 

,安裝PyMySQL

Python是編程語言,MySQL是資料庫,它們是兩種不同的技術;要想使Python操作MySQL資料庫需要使用驅動。這裡選用PyMySQL驅動。下載地址:

https://pypi.python.org/pypi/PyMySQL

https://github.com/PyMySQL/PyMySQL

當然,最簡單的安裝方式還是使用pip命令。

> pip install  PyMySQL

把install 換成show命令,查看PyMySQL安裝是否成功。

 

 

二,創建MySQL

執行下麵的SQL語句,創建一張users 表。

複製代碼
CREATE TABLE `users` (
    `id` INT(11) NOT NULL AUTO_INCREMENT,
    `email` VARCHAR(255) COLLATE utf8_bin NOT NULL,
    `password` VARCHAR(255) COLLATE utf8_bin NOT NULL,
    PRIMARY KEY (`id`)
) ENGINE=INNODB DEFAULT CHARSET=utf8 COLLATE=utf8_bin
AUTO_INCREMENT=1 ;
複製代碼

 

 

三,Python操作MySQL

接下來才是重點,Python操作MySQL資料庫。

4.1插入數據:

複製代碼
import pymysql.cursors


# 連接MySQL資料庫
connection = pymysql.connect(host='127.0.0.1', port=3306, user='root', password='198876', db='guest', 
charset='utf8mb4', cursorclass=pymysql.cursors.DictCursor) # 通過cursor創建游標 cursor = connection.cursor() # 創建sql 語句,並執行 sql = "INSERT INTO `users` (`email`, `password`) VALUES ('[email protected]', '123456')" cursor.execute(sql) # 提交SQL connection.commit()
複製代碼

  不管你使用的是什麼工具或庫,連接資料庫這一步必不可少。host為資料庫的主機IP地址,portMySQL的預設埠號,user為數據的用戶名,password為資料庫的登錄密碼,db為資料庫的名稱。

  cursor()方法創建資料庫游標。

  execute()方法執行SQL語句。

  commit()將資料庫的操作真正的提交到數據。

 

4.2. 查詢數據

複製代碼
import pymysql.cursors


# 連接MySQL資料庫
connection = pymysql.connect(host='127.0.0.1', port=3306, user='root', password='198876', db='guest', charset='utf8mb4', cursorclass=pymysql.cursors.DictCursor)


# 通過cursor創建游標
cursor = connection.cursor()

# 執行數據查詢
sql = "SELECT `id`, `password` FROM `users` WHERE `email`='[email protected]'"
cursor.execute(sql)

#查詢資料庫單條數據
result = cursor.fetchone()
print(result)

print("-----------華麗分割線------------")

# 執行數據查詢
sql = "SELECT `id`, `password` FROM `users`"
cursor.execute(sql)

#查詢資料庫多條數據
result = cursor.fetchall()
for data in result:
    print(data)


# 關閉數據連接
connection.close()
複製代碼

   接下來的操作就是資料庫的查詢了。

  fetchone() 用於查詢單條數據。

  fetchall() 用於查詢多條數據。

  close() 最後不要忘記了關閉數據連接。

  運行結果:

{'password': '123456', 'id': 1}
-----------華麗分割線------------
{'password': '123456', 'id': 1}
{'password': '654321', 'id': 2}

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 第一步:在資料庫中建立要操作的信息表 如下圖: 第二步:實現對該信息表中數據的刪除功能 代碼如下:main(主頁面) <!DOCTYPE html><html> <head> <meta charset="UTF-8"> <title>刪除功能</title> <script src="bootst ...
  • 將圖像從一個顏色空間轉換為另一個。 該函數將輸入圖像從一個顏色空間轉換為另一個顏色空間。在從RGB顏色空間轉換的情況下,應明確指定通道的順序(RGB或BGR)。請註意,OpenCV中的預設顏色格式通常稱為RGB,但實際上是BGR(位元組相反)。因此,標準(24位)彩色圖像中的第一個位元組將為8位藍色分量 ...
  • Python基礎 1.寫在前面 最近在學習Python,對學習到的知識和學習中產生的思考或想法進行一些總結,儘量讓自己的知識邏輯結構顯得清晰並讓自己瞭解的更透徹一些。鑒於剛學習水平有限,一些想法和思考會留在以後實現和解決。 本人再用Python3.5版本,所以Python標準庫參考的是3.5.2版本 ...
  • 報錯信息 解決方法 應該是CA證書驗證失敗造成的錯誤,下載個CA證書 修改cafile路徑,保存 ...
  • age = 3 if age >= 18: print('your age is', age) elif age >= 10: print('your age is', age) else: print('your age is', age) s = input('birth: ') birth = ...
  • 在編寫爬蟲時,性能的消耗主要在IO請求中,當單進程單線程模式下請求URL時必然會引起等待,從而使得請求整體變慢。 1. 同步執行 2. 多線程執行(多個線程併發執行,時間長短取決於最長的URL請求) 3. 多進程執行(在CPU核心數足夠的情況下,多個進程並行執行,時間長短取決於最長的URL請求,理論 ...
  • 指針是一個特殊的變數,它裡面存儲的數值被解釋成為記憶體里的一個地址。 要搞清一個指針需要搞清指針的四方面的內容:指針的類型,指針所指向的 類型,指針的值或者叫指針所指向的記憶體區,還有指針本身所占據的記憶體區。讓我們分別說明。 先聲明幾個指針放著做例子: 例一: (1)int*ptr; (2)char*p ...
  • AJAX +JSON=》JSP AJAX AJAX 是一種在無需重新載入整個網頁的情況下,能夠更新部分網頁的技術。 通過在後臺與伺服器進行少量數據交換,AJAX 可以使網頁實現非同步更新。這意味著可以在不重新載入整個網頁的情況下,對網頁的某部分進行更新。 傳統的網頁(不使用 AJAX)如果需要更新內容 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...