电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術(shù)文章
文章詳情頁

Mysql數(shù)據(jù)庫反向生成Django里面的models指令方式

瀏覽:6日期:2023-10-15 07:54:34

python manage.py inspectdb

python manage.py inspect > app/models.py

補(bǔ)充知識(shí):Django框架MySQL數(shù)據(jù)庫到models模型的映射關(guān)系

一、前言

我的數(shù)據(jù)庫已經(jīng)用MySQL Workbench設(shè)計(jì)好了,也插入了一些測(cè)試數(shù)據(jù),現(xiàn)在開始在Django中設(shè)計(jì)models模型。本以為順風(fēng)順?biāo)瑳]想到也遇到一些bug,現(xiàn)在記錄一下踩坑填坑過程。

二、設(shè)計(jì)models模型

1. 如果數(shù)據(jù)庫中表的數(shù)量比較多,可以先導(dǎo)出,然后查看對(duì)應(yīng)表的字段,根據(jù)不同表設(shè)計(jì)不同的models類,根據(jù)同一張表的不同字段設(shè)計(jì)類屬性。

用MySQL Workbench導(dǎo)出數(shù)據(jù)庫操作:

Mysql數(shù)據(jù)庫反向生成Django里面的models指令方式

2. 打開credits.sql文件,credits表的信息是:

CREATE TABLE `credits` ( `user_id` varchar(64) NOT NULL, `credits_total` int(64) DEFAULT ’0’, `credits_buy` int(64) DEFAULT ’0’, `time_credits_buy` datetime(6) DEFAULT NULL, `credits_before_day` int(32) DEFAULT ’0’, `time_sign_before_day` datetime(6) DEFAULT NULL, PRIMARY KEY (`user_id`), CONSTRAINT `credits_ibfk_1` FOREIGN KEY (`user_id`) REFERENCES `visitors` (`user_id`) ON DELETE CASCADE ON UPDATE CASCADE) ENGINE=InnoDB DEFAULT CHARSET=utf8;

其中,credits表字段信息是:user_id,credits_total,credits_buy,time_credits_buy,credits_before_day,time_sign_before_day

主鍵是:user_id,也是外鍵,關(guān)聯(lián)了visitors表的user_id主鍵

3. 設(shè)計(jì)models類

from django.db import models # 積分信息class Credits(models.Model): # id = models.IntegerField(’id主鍵’, primary_key=True, auto_created=True) # user_id = models.ForeignKey(Visitors,on_delete=models.CASCADE,primary_key=True) user = models.ForeignKey(Visitors,on_delete=models.CASCADE,primary_key=True) credits_total = models.IntegerField(’總積分’,default=0) credits_buy = models.IntegerField(’購買的積分’,default=0) time_credits_buy = models.DateTimeField(’購買的時(shí)間’,auto_now_add=True) credits_before_day = models.IntegerField(’前一天簽到的積分’,default=0) time_sign_before_day = models.DateTimeField(’前一天簽到的時(shí)間’,default=None) class Meta(): # credits,為數(shù)據(jù)庫中的表名 db_table = ’credits’

注意:

注釋中,# user_id = models.ForeignKey(Visitors,on_delete=models.CASCADE,primary_key=True),是我最開始寫的user_id類屬性,存在問題,如下圖所示:

Mysql數(shù)據(jù)庫反向生成Django里面的models指令方式

解決方案:把user_id 改成user即可,user = models.ForeignKey(Visitors,on_delete=models.CASCADE,primary_key=True),正確如下圖:

Mysql數(shù)據(jù)庫反向生成Django里面的models指令方式

4. time_credits_buy = models.DateTimeField(’購買的時(shí)間’,auto_now_add=True),time_credits_buy類屬性是時(shí)間類型,數(shù)據(jù)庫中credits表對(duì)應(yīng)的也是時(shí)間類型。

注意,剛開始,我的數(shù)據(jù)庫中把 time_credits_buy 字段設(shè)置為varchar(64)類型,而models模型中設(shè)置為時(shí)間類型,兩邊的類型不一致出現(xiàn)bug,如下圖所示:

Mysql數(shù)據(jù)庫反向生成Django里面的models指令方式

特別注意,數(shù)據(jù)庫中的字段類型,一定要和models定義的類屬性類型一致,否則報(bào)錯(cuò),有的時(shí)候很難發(fā)現(xiàn)bug

三、Django自動(dòng)生成models

>>> python manage.py inspectdb > app/models.py

如果數(shù)據(jù)庫表已經(jīng)存在,執(zhí)行命令,可以自動(dòng)生成Models模型,實(shí)現(xiàn)models與數(shù)據(jù)表的映射

以上這篇Mysql數(shù)據(jù)庫反向生成Django里面的models指令方式就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: MySQL 數(shù)據(jù)庫
相關(guān)文章:
主站蜘蛛池模板: 吸音板,隔音板,吸音材料,吸音板价格,声学材料 - 佛山诺声吸音板厂家 | 带锯机|木工带锯机圆木推台锯|跑车带锯机|河北茂业机械制造有限公司| | 北京森语科技有限公司-模型制作专家-展览展示-沙盘模型设计制作-多媒体模型软硬件开发-三维地理信息交互沙盘 | 南京试剂|化学试剂|分析试剂|实验试剂|cas号查询-专业60年试剂销售企业 | 天津散热器_天津暖气片_天津安尼威尔散热器制造有限公司 | 真空泵维修保养,普发,阿尔卡特,荏原,卡西亚玛,莱宝,爱德华干式螺杆真空泵维修-东莞比其尔真空机电设备有限公司 | 酶联免疫分析仪-多管旋涡混合仪|混合器-莱普特科学仪器(北京)有限公司 | 盘扣式脚手架-附着式升降脚手架-移动脚手架,专ye承包服务商 - 苏州安踏脚手架工程有限公司 | 家乐事净水器官网-净水器厂家「官方」 | 2025世界机器人大会_IC China_半导体展_集成电路博览会_智能制造展览网 | 科昊仪器超纯水机系统-可成气相液氮罐-美菱超低温冰箱-西安昊兴生物科技有限公司 | GAST/BRIWATEC/CINCINNATI/KARL-KLEIN/ZIEHL-ABEGG风机|亚喜科技 | SDI车窗夹力测试仪-KEMKRAFT方向盘测试仪-上海爱泽工业设备有限公司 | 编织人生 - 权威手工编织网站,编织爱好者学习毛衣编织的门户网站,织毛衣就上编织人生网-编织人生 | 东莞爱加真空科技有限公司-进口真空镀膜机|真空镀膜设备|Polycold维修厂家 | 工业胀紧套_万向节联轴器_链条-规格齐全-型号选购-非标订做-厂家批发价格-上海乙谛精密机械有限公司 | 高速龙门架厂家_监控杆_多功能灯杆_信号灯杆_锂电池太阳能路灯-鑫世源照明 | 比亚迪叉车-比亚迪电动叉车堆垛车托盘车仓储叉车价格多少钱报价 磁力去毛刺机_去毛刺磁力抛光机_磁力光饰机_磁力滚抛机_精密金属零件去毛刺机厂家-冠古科技 | 重庆钣金加工厂家首页-专业定做监控电视墙_操作台 | 航空障碍灯_高中低光强航空障碍灯_民航许可认证航空警示灯厂家-东莞市天翔航天科技有限公司 | 「安徽双凯」自动售货机-无人售货机-成人用品-自动饮料食品零食售货机 | 镀锌钢格栅_热镀锌格栅板_钢格栅板_热镀锌钢格板-安平县昊泽丝网制品有限公司 | 烟气在线监测系统_烟气在线监测仪_扬尘检测仪_空气质量监测站「山东风途物联网」 | 防爆大气采样器-防爆粉尘采样器-金属粉尘及其化合物采样器-首页|盐城银河科技有限公司 | 湖南印刷厂|长沙印刷公司|画册印刷|挂历印刷|台历印刷|杂志印刷-乐成印刷 | 智能监控-安防监控-监控系统安装-弱电工程公司_成都万全电子 | 接地电阻测试仪[厂家直销]_电缆故障测试仪[精准定位]_耐压测试仪-武汉南电至诚电力设备 | 钢板仓,大型钢板仓,钢板库,大型钢板库,粉煤灰钢板仓,螺旋钢板仓,螺旋卷板仓,骨料钢板仓 | 超声波电磁流量计-液位计-孔板流量计-料位计-江苏信仪自动化仪表有限公司 | 除尘布袋_液体过滤袋_针刺毡滤料-杭州辉龙过滤技术有限公司 | 无线讲解器-导游讲解器-自助讲解器-分区讲解系统 品牌生产厂家[鹰米讲解-合肥市徽马信息科技有限公司] | 户外环保不锈钢垃圾桶_标识标牌制作_园林公园椅厂家_花箱定制-北京汇众环艺 | 无线联网门锁|校园联网门锁|学校智能门锁|公租房智能门锁|保障房管理系统-KEENZY中科易安 | 防腐储罐_塑料储罐_PE储罐厂家_淄博富邦滚塑防腐设备科技有限公司 | 奥因-光触媒除甲醛公司-除甲醛加盟公司十大品牌 | 辊道窑炉,辊道窑炉厂家-山东艾希尔| 珠海白蚁防治_珠海灭鼠_珠海杀虫灭鼠_珠海灭蟑螂_珠海酒店消杀_珠海工厂杀虫灭鼠_立净虫控防治服务有限公司 | 环讯传媒,永康网络公司,永康网站建设,永康小程序开发制作,永康网站制作,武义网页设计,金华地区网站SEO优化推广 - 永康市环讯电子商务有限公司 | 通辽信息港 - 免费发布房产、招聘、求职、二手、商铺等信息 www.tlxxg.net | 气动机械手-搬运机械手-气动助力机械手-山东精瑞自动化设备有限公司 | 工装定制/做厂家/公司_工装订做/制价格/费用-北京圣达信工装 |