本文目錄一覽:
django怎麼使用mysql
首先,pip install pymysql
然後通過客戶端或別的工具進入mysql資料庫,創建數據表,比如user
在settings里:
# Database
#
import pymysql # 一定要添加這兩行!
pymysql.install_as_MySQLdb()
DATABASES = {
‘default’: {
‘ENGINE’: ‘django.db.backends.mysql’,
‘NAME’: ‘user’,
‘HOST’: ‘192.168.1.120’,
‘USER’: ‘root’,
‘PASSWORD’: ‘123’,
‘PORT’: ‘3306’,
}
}
最後還要在Django中,執行migrations和migrate。
推薦Django免費學習網站,劉江的Django教程,相當不錯。
django怎麼使用mysql資料庫
方法/步驟
修改setting.py裡面的DATABASES元組為
DATABASES = {
‘default’: {
‘ENGINE’: ‘django.db.backends.mysql’,
‘NAME’: ‘books’, #你的資料庫名稱
‘USER’: ‘root’, #你的資料庫用戶名
‘PASSWORD’: ”, #你的資料庫密碼
‘HOST’: ”, #你的資料庫主機,留空默認為localhost
‘PORT’: ‘3306’, #你的資料庫埠
}
}
INSTALLED_APPS = (
‘books’,#你的資料庫名稱
)
在mysql裡面創建books資料庫
檢查配置是否有語法錯誤
使用python manage.py sqlall books 顯示mysql語法
使用python manage.py syncdb同步模型中的資料庫
創建成功!
django怎麼使用本機mysql資料庫
step 1:
修改你的django project目錄下的settings.py 文件至如下所示:
其中,’NAME’ 對應的 『db_name’ 是你事先使用mysql
的命令行提示符創建的資料庫名稱。注意:在django使用資料庫之前,你必須先創建出資料庫,否則會報錯。’USER’對應的’username’
還有 ‘PASSWORD’ 對應的『passwd’
就是你在mysql中創建的用戶名和密碼。如果你有多個的話,隨便填一個就好。’HOST’和’PORT’默認都可以不填。
題外話: 使用用戶名和密碼登錄mysql的方法:
首先,你需要進入 mysql/bin的目錄下,也可以在.bash_profile中設置環境變數:
PATH=/usr/local/bin:/usr/bin:/bin:/sbin:/usr/sbin:/usr/local/sbin:/usr/local/Cellar/mysql/5.6.22/bin/
再在prompt輸入 mysql -u username -p, 回車後再輸入 passwd即可
step 2:
然後,在manage.py路徑中使用python manage.py syncdb 試試,結果會提示你錯誤找不到 MySQLdb 這個module, 為什麼呢, 因為 python manage.py syncdb 命令是這樣工作的:
1. 在project目錄的settings.py的INSTALLED_APPS元組中找到可能需要更新的APP。
2. 找到每一個APP目錄中的models.py (關係定義文件),並針對變化在資料庫中進行更新。
說了這麼多,前面那個錯誤 找不到 module MySQLdb 是什麼意思啊 ?
先給個圖,再解釋:
因為在models.py中定義關係使用的是python,而真正在資料庫中操作形成model當然一定要用sql語句,所以必須要有一些功能模塊
來把python語句轉化成sql語句。如果你使用sqlite的話,由於sqlite和轉化模塊都已經由python內置了,所以直接使用不會發生錯
誤。但是 」mysql語句的轉化模塊「 就需要你手動載入了,這些模塊放在 MySQL-python 中。
我是使用pip 安裝的:
安裝了之後,再使用 python manage.py syncdb就OK啦。
我使用的系統是 OS X,下面是 mysql 默認的安裝路徑
/usr/local/Cellar/mysql/5.6.22/
如果你想知道你的資料庫文件是放在哪裡的,你可以查看mysql_config文件中的ldata變數,這個變數的值就是 默認的資料庫文件夾存儲的路徑。 我的系統中,mysql_config的完整路徑是 :
/usr/local/Cellar/mysql/5.6.22/bin/mysql_config
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/295357.html