詳解關(guān)于Django中ORM數(shù)據(jù)庫(kù)遷移的配置
簡(jiǎn)介
ORM:
關(guān)系對(duì)象映射。定義一個(gè)類(lèi)自動(dòng)生成數(shù)據(jù)庫(kù)的表結(jié)構(gòu)。
創(chuàng)建數(shù)據(jù)庫(kù)的時(shí)候,一般有以下幾種常用數(shù)據(jù)類(lèi)型:數(shù)字、字符串以及時(shí)間。
ORM分為兩種:
- DB First 數(shù)據(jù)庫(kù)里先創(chuàng)建數(shù)據(jù)庫(kù)表結(jié)構(gòu),根據(jù)表結(jié)構(gòu)生成類(lèi),根據(jù)類(lèi)操作數(shù)據(jù)庫(kù)
- Code First 先寫(xiě)代碼,執(zhí)行代碼創(chuàng)建數(shù)據(jù)庫(kù)表結(jié)構(gòu)
主流的orm都是code first。django 的orm也是code first,所以學(xué)的時(shí)候,本質(zhì)就分為兩塊:
- 根據(jù)類(lèi)自動(dòng)創(chuàng)建數(shù)據(jù)庫(kù)表
- 根據(jù)類(lèi)對(duì)數(shù)據(jù)庫(kù)表中的數(shù)據(jù)進(jìn)行各種操作
手動(dòng)創(chuàng)建mysql數(shù)據(jù)庫(kù),例如db_Django03
create database root charset=utf8;
1,若想將模型轉(zhuǎn)為mysql數(shù)據(jù)庫(kù)中的表,需要在settings中配置:
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME':'bms', # 要連接的數(shù)據(jù)庫(kù),連接前需要?jiǎng)?chuàng)建好
'USER':'root', # 連接數(shù)據(jù)庫(kù)的用戶名
'PASSWORD':'', # 連接數(shù)據(jù)庫(kù)的密碼
'HOST':'127.0.0.1', # 連接主機(jī),默認(rèn)本級(jí)
'PORT':3306 # 端口 默認(rèn)3306
}
}
2,需要激活我們的mysql。然后,啟動(dòng)項(xiàng)目,會(huì)報(bào)錯(cuò):no module named MySQLdb 。這是因?yàn)閐jango默認(rèn)你導(dǎo)入的驅(qū)動(dòng)是MySQLdb,可是MySQLdb 對(duì)于py3有很大問(wèn)題,所以我們需要的驅(qū)動(dòng)是PyMySQL 所以,我們只需要找到項(xiàng)目名文件下的init,在里面寫(xiě)入:
import pymysql pymysql.install_as_MySQLdb()
*注意1,需確保配置文件中的INSTALLED_APPS中寫(xiě)入我們創(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,如果報(bào)錯(cuò)如下:
django.core.exceptions.ImproperlyConfigured: mysqlclient 1.3.3 or newer is required; you have 0.7.11.None
MySQLclient目前只支持到python3.4,因此如果使用的更高版本的python,需要修改如下:
通過(guò)查找路徑C:\Programs\Python\Python36-32\Lib\site-packages\Django-2.0-py3.6.egg\django\db\backends\mysql 這個(gè)路徑里的文件把
if version < (1, 3, 3):
raise ImproperlyConfigured("mysqlclient 1.3.3 or newer is required; you have %s" % Database.__version__)
注釋掉 就OK了。
*注意3,如果想打印orm轉(zhuǎn)換過(guò)程中的sql,需要在settings中進(jìn)行如下配置:
LOGGING = {
'version': 1,
'disable_existing_loggers': False,
'handlers': {
'console':{
'level':'DEBUG',
'class':'logging.StreamHandler',
},
},
'loggers': {
'django.db.backends': {
'handlers': ['console'],
'propagate': True,
'level':'DEBUG',
},
}
}
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
python實(shí)現(xiàn)爬蟲(chóng)統(tǒng)計(jì)學(xué)校BBS男女比例之?dāng)?shù)據(jù)處理(三)
這篇文章主要介紹了python實(shí)現(xiàn)爬蟲(chóng)統(tǒng)計(jì)學(xué)校BBS男女比例之?dāng)?shù)據(jù)處理,需要的朋友可以參考下2015-12-12
Python-OpenCV:cv2.imread(),cv2.imshow(),cv2.imwrite()的區(qū)別
本文主要介紹了OpenCV cv2.imread(),cv2.imshow(),cv2.imwrite()的區(qū)別,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-06-06
如何通過(guò)pycharm實(shí)現(xiàn)對(duì)數(shù)據(jù)庫(kù)的查詢等操作(非多步操作)
這篇文章主要介紹了如何通過(guò)pycharm實(shí)現(xiàn)對(duì)數(shù)據(jù)庫(kù)的查詢等操作(非多步操作),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-07-07
python捕獲異常后繼續(xù)執(zhí)行問(wèn)題
這篇文章主要介紹了python捕獲異常后繼續(xù)執(zhí)行問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-09-09
Python利用三層神經(jīng)網(wǎng)絡(luò)實(shí)現(xiàn)手寫(xiě)數(shù)字分類(lèi)詳解
這篇文章主要介紹了如何設(shè)計(jì)一個(gè)三層神經(jīng)網(wǎng)絡(luò)模型來(lái)實(shí)現(xiàn)手寫(xiě)數(shù)字分類(lèi)。本文給大家介紹的非常詳細(xì),感興趣的小伙伴快來(lái)跟小編一起學(xué)習(xí)一下2021-11-11
pycharm安裝教程(下載安裝以及設(shè)置中文界面)
這篇文章主要給大家介紹了關(guān)于pycharm安裝教程,文中包括下載安裝以及設(shè)置中文界面,PyCharm是一款Python IDE,其帶有一整套可以幫助用戶在使用Python語(yǔ)言開(kāi)發(fā)時(shí)提高其效率的工具,需要的朋友可以參考下2023-10-10

