首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >【愚公系列】2021年12月 Python教学课程 33-Django框架之模型

【愚公系列】2021年12月 Python教学课程 33-Django框架之模型

作者头像
愚公搬代码
发布于 2022-12-01 01:56:36
发布于 2022-12-01 01:56:36
61200
代码可运行
举报
文章被收录于专栏:历史专栏历史专栏
运行总次数:0
代码可运行

文章目录


一、模型类的定义

代码如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
from django.db import models

# Create your models here.
# 准备书籍列表信息的模型类
class BookInfo(models.Model):
    # 创建字段,字段类型...
    name = models.CharField(max_length=10)

# 准备人物列表信息的模型类
class PeopleInfo(models.Model):
    name = models.CharField(max_length=10)
    gender = models.BooleanField()
    # 外键约束:人物属于哪本书
    book = models.ForeignKey(BookInfo)

1.字段及参数

CharField: .要求必须有参数 maxlength,限制该字段的最大字符数;

IntegerField :用于保存整数;

DecimalField :浮点数. 必须 提供两个参数:max_digits 总位数,decimal_places 小数位数;

DateField :日期字段,年月日;

DateTimeField :年月日时分秒;

对于日期字段需要注意的参数:

auto_now:每次操作改数据都会自动更新时间;

auto_now_add:新增数据的时候会将当前时间自动添加,后续的修改该字段不会自动更新。

EmailField:带有检查Email合法性的 CharField,不接受 maxlength 参数.

ForeignKey:外键字段,设置在 '一对多’中’多’的一方;

OneToOneField:一对一字段,用来扩展已有字段

ManyToManyFiled:多对多字段,建议设置在查询频率较高的表中

二、数据库配置

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
DATABASES = {
    'default': {          
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'blog',    #你的数据库名称 数据库需要自己提前建好
        'USER': 'root',   #你的数据库用户名
        'PASSWORD': '', #你的数据库密码
        'HOST': '', #你的数据库主机,留空默认为localhost
        'PORT': '3306', #你的数据库端口
    }
}

三、模型迁移 (建表)

迁移由两步完成 :

生成迁移文件:根据模型类生成创建表的语句

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
python manage.py makemigrations

执行迁移:根据第一步生成的语句在数据库中创建表

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
python manage.py migrate

迁移之后出现0001的文件,就代表数据库迁移完成,数据库有对应的表

四、单独的py文件测试ORM操作需要配置的参数

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import os

if __name__ == "__main__":
  os.environ.setdefault("DJANGO_SETTINGS_MODULE", "day58.settings")
  import django  django.setup()
  from app01 import models  # 这一句话必须在这下面导入
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021-04-02,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
【愚公系列】2022年01月 Python教学课程 40-Django框架之模型属性详解
模型类如果未指明表名,Django默认以小写app应用名_小写模型类名为数据库表名。
愚公搬代码
2022/12/01
1.6K0
Django——模型Model
对象关系映射(Object Relation Mapping)实现了关系和数据库之间的映射,隐藏了关系数据访问的细节,不需要再编写SQL语句
羊羽shine
2019/05/28
8850
Django 学习笔记 | 2、模型
在这之前需要先设计数据库的表什么的,这里就不详细的说了(主要是我太懒了),感兴趣的可以看本文的参考链接,下面直接贴定义模型类的代码。
TeamsSix
2020/03/12
7010
【愚公系列】2021年12月 Python教学课程 34-Django框架之站点管理
为工作人员或客户生成管理、添加、更改和删除内容的管理站点是一项单调乏味的工作,不需要太多的创造性。为此,Django完全自动化模型的创建管理界面。
愚公搬代码
2022/12/01
5770
【愚公系列】2021年12月 Python教学课程 34-Django框架之站点管理
【Django】基于PythonWeb的Django框架设计实现天天生鲜系统-3模型创建
当前项目的开发都是数据库驱动,即分析出项目中所需要存储的数据,然后设计数据表结构,接下来对通过编写 SQL 语句对数据库中的表进行 CURD 操作。
天道Vax的时间宝藏
2021/08/11
1.3K0
Django教程 —— 模型设计
我们一般操作数据库的时候都是通过写sql语句,那么能不能不写sql语句就可以操作数据库呢? 可以利用ORM框架。
忆想不到的晖
2020/11/06
1.2K0
Django—模型
ORM,全拼Object-Relation Mapping,中文意为对象-关系映射,是随着面向对象的软件开发方法发展而产生的。面向对象的开发方法是当今企业级应用开发环境中的主流开发方法,关系数据库是企业级应用环境中永久存放数据的主流数据存储系统。对象和关系数据是业务实体的两种表现形式,业务实体在内存中表现为对象,在数据库中表现为关系数据。内存中的对象之间存在关联和继承关系,而在数据库中,关系数据无法直接表达多对多关联和继承关系。因此,对象-关系映射ORM系统一般以中间件的形式存在,主要实现程序对象到关系数据库数据的映射。面向对象是从软件工程基本原则(如耦合、聚合、封装)的基础上发展起来的,而关系数据库则是从数学理论发展而来的,两套理论存在显著的区别。为了解决这个不匹配的现象,对象关系映射技术应运而生。O/R中字母O起源于"对象"(Object),而R则来自于"关系"(Relational)。几乎所有的程序里面,都存在对象和关系数据库。在业务逻辑层和用户界面层中,我们是面向对象的。当对象信息发生变化的时候,我们需要把对象的信息保存在关系数据库中。目前流行的ORM产品如Java的Hibernate,.Net的EntityFormerWork等。
py3study
2020/01/16
6.7K0
Django—模型
Django设计模型1.2
设计介绍 本示例完成“图书-英雄”信息的维护,需要存储两种数据:图书、英雄 图书表结构设计: 表名:BookInfo 图书名称:btitle 图书发布时间:bpub_date 英雄表结构设计: 表名:HeroInfo 英雄姓名:hname 英雄性别:hgender 英雄简介:hcontent 所属图书:hbook 图书-英雄的关系为一对多 数据库配置 在settings.py文件中,通过DATABASES项进行数据库设置 django支持的数据库包括:sqlite、mysql等主流数据库 D
Lansonli
2021/10/09
5120
Django 2.1.7 基于默认sqlite3 模型设计 以及 数据操作
一般操作数据库是通过写sql语句,那么能不能不写sql语句就可以操作数据库呢? 可以,就是通过接下来要给大家讲的ORM框架。
Devops海洋的渔夫
2019/06/11
1.1K0
Django 2.1.7 基于默认sqlite3 模型设计 以及 数据操作
Django ORM
ps:如果inspectdb后不跟表名,那么就会将该数据库内的所有表反向解析成类(python语句)
HammerZe
2022/03/25
4.3K0
Django ORM
django_mysql_配置
1. 创建一个新的应用,为booktest,在models.py 文件中定义模型类,然后去setting注册应用
py3study
2020/01/16
1.7K0
探索 Python/Django 支持分布式多租户数据库,如 Postgres+Citus
在 确定分布策略 中,我们讨论了在多租户用例中使用 Citus 所需的与框架无关的数据库更改。在这里,我们专门研究如何借助 django-multitenant 库将多租户 Django 应 用程序迁移到 Citus 存储后端。
为少
2022/05/18
2.4K0
探索 Python/Django 支持分布式多租户数据库,如 Postgres+Citus
python-Django-Django 数据库迁移(二)
其中,app_name是我们要创建迁移文件的应用程序的名称。如果我们没有指定app_name,Django会自动检测出我们最近修改的模型,并为其创建新的迁移文件。
玖叁叁
2023/04/23
9170
Django教程 —— 初步完善图书管理系统
我们写项目写东西的时候都要养成良好的习惯,不要一来就上手写代码,我们先要进行初步分析和设计,让大脑有整体的概念,需要用到什么技术实现什么效果。这个习惯也不能学的太死,我们要活学活用,学会变通。有时候只是简单的学习一下,或者简单的实现一个小功能。大脑已经可以大概掌握,就无须设计与分析。
忆想不到的晖
2020/11/06
1.1K0
Django - 模型层以及如何通过模型层来建表
模型 Django 提供了一个抽象的模型 ("models") 层, 什么是模型层? 这里模型的思想与Java中的ORM(Object Relationship Mapping) 对象关系映射类似 模型准确且唯一的描述了数据 它包含要储存的数据的字段 一般来说,每一个模型都映射一张数据库表 如何创建模型? 每个模型都是一个 Python 的类,这些类继承 django.db.models.Model 模型类的每个属性都相当于一个数据库的字段 利用这些,Django 提供了一个自动生成访问数据库
桑鱼
2020/03/27
9810
『Django』模型入门教程-操作MySQL
一个后台如果没有数据库可以说废了一半。日常开发中大多数时候都在与数据库打交道。Django 为我们提供了一种更简单的操作数据库的方式。
德育处主任
2024/06/27
2750
『Django』模型入门教程-操作MySQL
Django 2.x实战(02) - 深入模型
其他的配置可以参考官方文档中数据库配置的部分。 NAME属性代表数据库的名称,如果使用SQLite它对应着一个文件,在这种情况下NAME的属性值应该是一个绝对路径。如果使用其他关系型数据库,还要配置对应的HOST(主机)、PORT(端口)、USER(用户名)、PASSWORD(口令)等属性。
用户8442333
2021/05/20
5080
1.4 Django基础篇--数据库模型设计
新书小广告 《Python爬虫开发与项目实战》基础篇 试读章节链接: http://pan.baidu.com/s/1hrWEOYg 这本书包括基础篇,中级篇和深入篇三个部分,不仅适合零基础的朋友入门,也适合有一定基础的爬虫爱好者进阶,如果你不会分布式爬虫,不会千万级数据的去重,不会怎么突破反爬虫,不会分析js的加密,这本书会给你惊喜。 前言 从上一节我们知道home应用需要涉及文章,分类和标签三个部分,其实这就是个人博客系统最核心的功能:发表文章。下面我们分析一下数据库
七夜安全博客
2018/06/26
1.4K0
ORM
class BookInfo(models.Model): # 每一个字段对应 表中的一列 title = models.CharField(max_length=30) # auto_now_add=True 意味着默认时间为 该行插入时间 pub_date = models.DateTimeField(auto_now_add=True)
爱喝水的木子
2022/01/12
5350
Django—入门
举个简单的例子,对于一个公司来说,公司中有各个职能部门,每个部门各司其职,通过部门之间的配合来完成工作,这些部门就形成了一个公司的组织架构。从某种意义上来说,公司就是一种框架。那么对应到软件设计上来说,软件框架是由其中的各个模块组成的,每个模块负责特定的功能,模块与模块之间相互协作来完成软件开发。
py3study
2020/01/16
2.1K0
Django—入门
推荐阅读
相关推荐
【愚公系列】2022年01月 Python教学课程 40-Django框架之模型属性详解
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验