關於Django中ORM資料庫遷移的配置
Django中ORM資料庫遷移配置
1,若想將模型轉為mysql資料庫中的表,需要在settings中配置:
DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME':'bms', # 要連線的資料庫,連線前需要建立好 'USER':'root', # 連線資料庫的使用者名稱 'PASSWORD':'', # 連線資料庫的密碼 'HOST':'127.0.0.1',# 連線主機,預設本級 'PORT':3306 #埠 預設3306 } }
2,需要啟用我們的mysql。然後,啟動專案,會報錯:no module named SQL/">MySQLdb 。這是因為django預設你匯入的驅動是MySQLdb,可是MySQLdb 對於py3有很大問題,所以我們需要的驅動是PyMySQL 所以,我們只需要找到專案名檔案下的init,在裡面寫入:
import pymysql pymysql.install_as_MySQLdb()
*注意1,需確保配置檔案中的INSTALLED_APPS中寫入我們建立的app名稱
INSTALLED_APPS = [ 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', "book" ]
*注意2,如果報錯如下:
django.core.exceptions.ImproperlyConfigured: mysqlclient 1.3.3 or newer is required; you have 0.7.11.None
MySQLclient目前只支援到python3.4,因此如果使用的更高版本的python,需要修改如下:
通過查詢路徑C:\Programs\Python\Python36-32\Lib\site-packages\Django-2.0-py3.6.egg\django\db\backends\mysql 這個路徑裡的檔案把
if version < (1, 3, 3): raise ImproperlyConfigured("mysqlclient 1.3.3 or newer is required; you have %s" % Database.__version__)
註釋掉 就OK了。
*注意3,如果想列印orm轉換過程中的sql,需要在settings中進行如下配置:
LOGGING = { 'version': 1, 'disable_existing_loggers': False, 'handlers': { 'console':{ 'level':'DEBUG', 'class':'logging.StreamHandler', }, }, 'loggers': { 'django.db.backends': { 'handlers': ['console'], 'propagate': True, 'level':'DEBUG', }, } }