方案一:直接連接MySQL數(shù)據(jù)庫
-
創(chuàng)建連接文件
創(chuàng)建MySQL.py文件,用來配置和MySQL數(shù)據(jù)庫連接(應(yīng)該也可以做到config.py里)口叙,具體代碼如下:
import mysql.connector
#我查閱了發(fā)現(xiàn)使用這個(gè)應(yīng)該得有個(gè)mysql-connector的模塊,
#我不知道是啥時(shí)候安裝的了胖秒,反正先用著吧馆匿,以后再做筆記滞欠。
conn = mysql.connector.connect(user='root', password='1234', database='db')
- 引用MySQL.py
import MySQL
- 在視圖函數(shù)中調(diào)用
# 1. 創(chuàng)建連接
c = MySQL.conn.cursor()
# 2. 執(zhí)行查詢
c.execute('select * from products')
# 3. 取出所有結(jié)果忙菠,放到一個(gè)list里
products = c.fetchall()
# 4. 將list返回給頁面中的list何鸡,并進(jìn)行渲染
return render_template("list.html",
title='Home',
products = products
)
-
html頁面模版中的顯示
list.html
核心代碼
<!-----顯示產(chǎn)品信息列表----->
{% for p in products %}
<p>{{ p[0] }},{{ p[1] }}牛欢,{{ p[2] }}</p>
{% endfor %}
本方法心得:
1骡男、使用簡單,跟ASP傍睹、PHP等類似洞翩。
2、在安裝了pymysql之后焰望,將代碼中的mysql替換成pymysql,也能執(zhí)行已亥。不知道是本身mysql這個(gè)模塊就是安裝pymsql之后就才能用熊赖,還是說pymysql是繼承了mysql模塊的基本功能?(還要進(jìn)一步學(xué)習(xí)練習(xí))
方案二:pymysql方法
-
安裝pymysql
python3 采用pymysql 連接MySQL,棄用了mysqldb虑椎,所以python3下得先安裝pymysql
pip install PyMySQL
-
創(chuàng)建連接配置文件MySQL
新建一個(gè)MySQL.py
作為連接MySQL數(shù)據(jù)庫的配置文件震鹉,代碼如下:
import pymysql
conn = pymysql.connect(user='root', password='8792535', database='cis_cd')
跟方案一中的類似吧?眼熟捆姜。
-
后面的就是重復(fù)方案一的步驟
就不詳細(xì)敘述了传趾。但是發(fā)現(xiàn)一個(gè)問題,采用mysql connector連接沒問題泥技,但是到了pymysql連接后浆兰,就出現(xiàn)字符亂碼問題。
本方法心得:
方法簡單
但我還沒有搞清楚mysql模塊和pymysql模塊的異同。還要加油簸呈。
方案三:高大上的SQLAlchemy
常見錯(cuò)誤
-
Python2和Python3的連接模塊
Python3默認(rèn)是沒有驅(qū)動去直接連接和操作MySQL的榕订,Python3里棄用了Python2的MySQLdb模塊,如果直接使用蜕便,會報(bào)以下錯(cuò)誤:
ImportError: No module named 'MySQLdb'
可能和一些網(wǎng)上教程出入的地方在這里劫恒。
解決方案如下:
- 首先肯定得安裝PyMySQL
pip install PyMySQL
- 加入以下代碼
import pymysql
pymysql.install_as_MySQLdb()
測試成功通過
一些需要記得的有用的東東
- ** ORM**
Object - Relationship - Mapping