django如何根據(jù)現(xiàn)有數(shù)據(jù)庫表生成model詳解
題記:django如果要并和原有的數(shù)據(jù)庫,那么就需要把現(xiàn)有數(shù)據(jù)庫的表寫入model.py中。
一,在setting.py中配置好連接數(shù)據(jù)庫的參數(shù)
在setting中的DATABASESZ中配置默認參數(shù),并在INSTALLED_APPS中導入模塊名。
DATABASES = {
'default':
{
'ENGINE': 'django.db.backends.mysql', # 數(shù)據(jù)庫引擎
'NAME': 'jljupcs', # 數(shù)據(jù)庫名稱
'HOST': '127.0.0.1', # 數(shù)據(jù)庫地址,本機 ip 地址 127.0.0.1
'PORT': 3306, # 端口
'USER': 'root', # 數(shù)據(jù)庫用戶名
'PASSWORD': '', # 數(shù)據(jù)庫密碼
}
}
# Application definition
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'conversion',
]
在主項目目錄下導入pymysql
import pymysql pymysql.install_as_MySQLdb()

二,打開cmd或pycharm的Terminal輸入命令
輸入命令:
python manage.py inspectdb > [項目路徑]/models.py
在cmd中輸入命令:

打開pycharm終端輸入命令:

最后在models.py中自動創(chuàng)建了數(shù)據(jù)庫表對應的類。

三,managed = False 刪除或改為 managed = True
修改managed讓之后修改models即可對數(shù)據(jù)庫進行操作,在終端輸入:
python manage.py inspectdb
提示如果你想讓Django創(chuàng)建、修改和刪除表,請刪除’ managed = False '行

四,執(zhí)行遷移
在終端輸入:
python manage.py makemigrations
python manage.py migrate

補充:Django根據(jù)數(shù)據(jù)庫表反向生成Model
用過Django的人應該都熟悉下面兩條命令:
# 將Model的改動生成文件 python manage.py make migrations # 此時數(shù)據(jù)庫中還不會生效 # 提交改動 python manage.py migrate # 此時數(shù)據(jù)庫就會自動生成我們Model對應的數(shù)據(jù)表了
上面兩條命令都是作用于全局的,但是如果我們只想改動的app下面的Model或者某個文件中的Model,那就需要指定appname和filename:
# 生成指定app下面的改動文件 python manage.py makemigrations appname # 提交指定app下面指定的改動文件 python manage.py migrate appname filename
既然有根據(jù)Model自動生成數(shù)據(jù)庫表的命令,那么肯定就有根據(jù)數(shù)據(jù)庫表反向生成Model的命令
python manage.py inspectdb # 使用這條命令,會根據(jù)設置的數(shù)據(jù)庫中的表在自動生成對應的Model代碼,并打印出來
當然也可以直接將打印的代碼直接導入到指定的Model文件中
python manage.py inspectdb > student/models.py # 前提是創(chuàng)建了app(student)并且在setting.py文件中注冊過
配置了多個數(shù)據(jù)庫,則還可以配置數(shù)據(jù)庫別名來指定根據(jù)哪個庫中的表來生成Model
python manage.py inspectdb --database default >student/models.py # default是默認的別名
將指定的表生成對應的Model
python manage.py inspectdb --database default table1 table2 >student/models.py
總結
到此這篇關于django如何根據(jù)現(xiàn)有數(shù)據(jù)庫表生成model的文章就介紹到這了,更多相關django生成model內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
python利用xpath爬取網上數(shù)據(jù)并存儲到django模型中
這篇文章主要介紹了python利用xpath爬取網上數(shù)據(jù)并存儲到django模型中,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-02-02
基于SpringBoot構造器注入循環(huán)依賴及解決方式
這篇文章主要介紹了基于SpringBoot構造器注入循環(huán)依賴及解決方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-04-04
Python實現(xiàn)爬取天氣數(shù)據(jù)并可視化分析
這篇文章主要和大家分享一個用Python實現(xiàn)的小功能:獲取天氣數(shù)據(jù),進行可視化分析,帶你直觀了解天氣情況!感興趣的小伙伴可以學習一下2022-02-02
python實現(xiàn)可將字符轉換成大寫的tcp服務器實例
這篇文章主要介紹了python實現(xiàn)可將字符轉換成大寫的tcp服務器,通過tcp服務器端實現(xiàn)針對字符的轉換與返回功能,具有一定參考借鑒價值,需要的朋友可以參考下2015-04-04

