詳解關于Django中ORM數(shù)據(jù)庫遷移的配置
簡介
ORM:
關系對象映射。定義一個類自動生成數(shù)據(jù)庫的表結構。
創(chuàng)建數(shù)據(jù)庫的時候,一般有以下幾種常用數(shù)據(jù)類型:數(shù)字、字符串以及時間。
ORM分為兩種:
- DB First 數(shù)據(jù)庫里先創(chuàng)建數(shù)據(jù)庫表結構,根據(jù)表結構生成類,根據(jù)類操作數(shù)據(jù)庫
- Code First 先寫代碼,執(zhí)行代碼創(chuàng)建數(shù)據(jù)庫表結構
主流的orm都是code first。django 的orm也是code first,所以學的時候,本質就分為兩塊:
- 根據(jù)類自動創(chuàng)建數(shù)據(jù)庫表
- 根據(jù)類對數(shù)據(jù)庫表中的數(shù)據(jù)進行各種操作
手動創(chuàng)建mysql數(shù)據(jù)庫,例如db_Django03
create database root charset=utf8;
1,若想將模型轉為mysql數(shù)據(jù)庫中的表,需要在settings中配置:
DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME':'bms', # 要連接的數(shù)據(jù)庫,連接前需要創(chuàng)建好 'USER':'root', # 連接數(shù)據(jù)庫的用戶名 'PASSWORD':'', # 連接數(shù)據(jù)庫的密碼 'HOST':'127.0.0.1', # 連接主機,默認本級 'PORT':3306 # 端口 默認3306 } }
2,需要激活我們的mysql。然后,啟動項目,會報錯:no module named MySQLdb 。這是因為django默認你導入的驅動是MySQLdb,可是MySQLdb 對于py3有很大問題,所以我們需要的驅動是PyMySQL 所以,我們只需要找到項目名文件下的init,在里面寫入:
import pymysql pymysql.install_as_MySQLdb()
*注意1,需確保配置文件中的INSTALLED_APPS中寫入我們創(chuàng)建的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', }, } }
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
python實現(xiàn)爬蟲統(tǒng)計學校BBS男女比例之數(shù)據(jù)處理(三)
這篇文章主要介紹了python實現(xiàn)爬蟲統(tǒng)計學校BBS男女比例之數(shù)據(jù)處理,需要的朋友可以參考下2015-12-12Python-OpenCV:cv2.imread(),cv2.imshow(),cv2.imwrite()的區(qū)別
本文主要介紹了OpenCV cv2.imread(),cv2.imshow(),cv2.imwrite()的區(qū)別,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-06-06如何通過pycharm實現(xiàn)對數(shù)據(jù)庫的查詢等操作(非多步操作)
這篇文章主要介紹了如何通過pycharm實現(xiàn)對數(shù)據(jù)庫的查詢等操作(非多步操作),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-07-07Python利用三層神經網(wǎng)絡實現(xiàn)手寫數(shù)字分類詳解
這篇文章主要介紹了如何設計一個三層神經網(wǎng)絡模型來實現(xiàn)手寫數(shù)字分類。本文給大家介紹的非常詳細,感興趣的小伙伴快來跟小編一起學習一下2021-11-11