方案一:直接連接MySQL數據庫
-
創建連接文件
創建MySQL.py文件,用來配置和MySQL數據庫連接(應該也可以做到config.py里),具體代碼如下:
import mysql.connector
#我查閱了發現使用這個應該得有個mysql-connector的模塊,
#我不知道是啥時候安裝的了,反正先用著吧,以后再做筆記。
conn = mysql.connector.connect(user='root', password='1234', database='db')
- 引用MySQL.py
import MySQL
- 在視圖函數中調用
# 1. 創建連接
c = MySQL.conn.cursor()
# 2. 執行查詢
c.execute('select * from products')
# 3. 取出所有結果,放到一個list里
products = c.fetchall()
# 4. 將list返回給頁面中的list,并進行渲染
return render_template("list.html",
title='Home',
products = products
)
-
html頁面模版中的顯示
list.html
核心代碼
<!-----顯示產品信息列表----->
{% for p in products %}
<p>{{ p[0] }},{{ p[1] }},{{ p[2] }}</p>
{% endfor %}
本方法心得:
1、使用簡單,跟ASP、PHP等類似。
2、在安裝了pymysql之后,將代碼中的mysql替換成pymysql,也能執行。不知道是本身mysql這個模塊就是安裝pymsql之后就才能用,還是說pymysql是繼承了mysql模塊的基本功能?(還要進一步學習練習)
方案二:pymysql方法
-
安裝pymysql
python3 采用pymysql 連接MySQL,棄用了mysqldb,所以python3下得先安裝pymysql
pip install PyMySQL
-
創建連接配置文件MySQL
新建一個MySQL.py
作為連接MySQL數據庫的配置文件,代碼如下:
import pymysql
conn = pymysql.connect(user='root', password='8792535', database='cis_cd')
跟方案一中的類似吧?眼熟。
-
后面的就是重復方案一的步驟
就不詳細敘述了。但是發現一個問題,采用mysql connector連接沒問題,但是到了pymysql連接后,就出現字符亂碼問題。
本方法心得:
方法簡單
但我還沒有搞清楚mysql模塊和pymysql模塊的異同。還要加油。
方案三:高大上的SQLAlchemy
常見錯誤
-
Python2和Python3的連接模塊
Python3默認是沒有驅動去直接連接和操作MySQL的,Python3里棄用了Python2的MySQLdb模塊,如果直接使用,會報以下錯誤:
ImportError: No module named 'MySQLdb'
可能和一些網上教程出入的地方在這里。
解決方案如下:
- 首先肯定得安裝PyMySQL
pip install PyMySQL
- 加入以下代碼
import pymysql
pymysql.install_as_MySQLdb()
測試成功通過
一些需要記得的有用的東東
- ** ORM**
Object - Relationship - Mapping