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開發(fā)之基于模板匹配的信用卡數(shù)字識別功能
這篇文章主要介紹了基于模板匹配的信用卡數(shù)字識別功能,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2020-01-01
selenium?drag_and_drop不生效的解決辦法
本文主要介紹了selenium?drag_and_drop不生效的解決辦法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-03-03
Python web框架(django,flask)實現(xiàn)mysql數(shù)據(jù)庫讀寫分離的示例
這篇文章主要介紹了Python web框架(django,flask)實現(xiàn)mysql數(shù)據(jù)庫讀寫分離的示例,幫助大家更好的理解和學習python,感興趣的朋友可以了解下2020-11-11
零基礎寫python爬蟲之抓取百度貼吧并存儲到本地txt文件改進版
前面已經(jīng)發(fā)了一篇關于百度貼吧抓取的代碼,今天我們來看下代碼的改進版,參考了上篇抓取糗事百科的思路,給需要的小伙伴們參考下吧2014-11-11

