7.Django模型类的定义和管理
Django的模型类是给ORM层服务的
1.每个数据模型都是django.db.models.Model的子类。
2.它的父类Model包含了所有必要的和数据库交互的方法,并提供了定义数据库字段的语法。
3.每个模型相当于一个数据库表(这条规则的例外情况是多对多关系,多对多关系的时候会多生成一张关系表),
4.每个属性是表中的一个字段。属性名就是字段名,类型就是字段类型
5.模型之间的三种关系
一对一(OneToOneField)
一对多(ForeignKey)
多对多(ManyToMangField)
6.把定义的模型放到models.py里,这里就是:hello_django\hello\models.py文件
7.语法
class MyModel(models.Model):
name = models.CharField(max_length=30, verbose_name="名称")
class Meta:
verbose_name = '中文表明'
verbose_name_plural = verbose_name
def __str__(self):
return self.name
解释:
a.通过class定义models名称也就是数据库的表名
b.需要传入models.Model固定写法
c.在class的内部,通过name=models.XXXField(params)定义字段
c.1 models.XXXField常用选项
BooleanField:布尔类型
CharField:字符串varchar
DateField:日期
DateTimeField:时间戳
DecimalField:带小数的数
c.2 params常用选项:
null(null=True|False)数据库字段的是否可以为空
blank(blank=True|False)字段是否为空,表单验证
default 字段默认值
help_text 字段解释
primary_key 主键,一般不用显示定义,框架自动生成个id
unique 是否唯一,对数据库而言
verbose_name 字段详细名称,通常写自己的中文含义
c.3 详见:https://docs.djangoproject.com/en/1.9/ref/models/fields
d.通过内部类class Meta定义一些扩展属性
d.1例如:
class Meta:
verbose_name = '中文表明'
verbose_name_plural = verbose_name
d.2详见:https://docs.djangoproject.com/en/1.9/ref/models/options/
e.可以通过def定义内部的函数或者重写他的函数,可以提供具体的逻辑
e.1示例:定义__str__()让对象有个默认的名字(属于重写他的方法)
备注:python2里用__unicode__(),python3里是__str__()
7.通过manage.py生成数据库表
manage.py makemigrations (创建脚本)
manage.py migrate (执行脚本)
8.在hello_django\hello\admin.py加入管理后,可在admin界面管理,代码如下
from django.contrib import admin
from hello.models import *
# Register your models here.
admin.site.register(Author)
7.Django模型类的定义和管理的更多相关文章
- Django(十)模型:django模型类对数据库的:增/删/改/查、自关联、管理器、元选项(指定表名)
一.插入.更新和删除 调用一个模型类对象的save方法的时候就可以实现对模型类对应数据表的插入和更新. 调用一个模型类对象的delete方法的时候就可以实现对模型类对应数据表数据的删除. 二.自关联 ...
- Django模型Model的定义
概述 Django对各种数据库提供了很好的支持,Django为这些数据库提供了统一的调用API,可以根据不同的业务需求选择不同的数据库. 模型.属性.表.字段间的关系 一个模型类在数据库中对应一张表, ...
- Django进阶Model篇002 - 模型类的定义
一.创建数据模型. 实例: 作者模型:一个作者有姓名. 作者详情模型:把作者的详情放到详情表,包含性别.email 地址和出生日期,作者详情模型与作者模型之间是一对一的关系(OneToOneField ...
- Django模型类Meta元数据详解
转自:https://my.oschina.net/liuyuantao/blog/751337 简介 使用内部的class Meta 定义模型的元数据,例如: from django.db impo ...
- django模型类
模型类 ORM django中内嵌了ORM框架,ORM框架可以将类和数据表进行对应起来,只需要通过类和对象就可以对数据表进行操作. 在Django中主要是设计类:模型类. ORM另外一个作用:根据设计 ...
- Django | 模型类变更后生成迁移文件,报错:You are trying to add a non-nullable field 'BookName' to BookInfo without a default....
报错: You are trying to add a non-nullable field 'BookName' to BookInfo without a default; we can't do ...
- 8.Django模型类例子
这里定义4个模型 作者:一个作者有姓名 作者详情:包括性别,email,出生日期, 出版商:名称,地址,城市,省,国家,网站 书籍:名称,日期 分析: 作者详情和作者一对一的关系 一本书可以有多个作者 ...
- Django模型类之models字段类型和参数以及元数据meta
models之字段类型和参数 示例: # class Test(models.Model): # courses_test # """测试学习用""& ...
- django 模型类的常见字段约束,以及filter 过滤和查询
null 不设置时默认设置为False.设置为True时,数据库表字段中将存入NULL的记录. null和blank组合使用,null=True,blank=True,表示该字段可以为空 blank ...
随机推荐
- Spring管理的bean初始化方法的三种方式,以及@PostConstruct不起作用的原因
1:Spring 容器中的 Bean 是有生命周期的,spring 允许 Bean 在初始化完成后以及销毁前执行特定的操作.下面是常用的三种指定特定操作的方法: 通过实现InitializingBea ...
- HDU4911:Inversion
Problem Description bobo has a sequence a1,a2,-,an. He is allowed to swap two adjacent numbers for n ...
- 累加按钮,自加1&&输入两个数字,比较大小
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- java.lang.IllegalArgumentException: Wrong state classs
java.lang.IllegalArgumentException: Wrong state class, expecting View State but received class cn.et ...
- HBase伪分布式安装及简单使用
HBase是Hadoop的数据库,基于Hadoop执行.是一种NoSQL数据库. 特点:分布式.多版本号.面向列的存储模型.可以大规模的数据实时随机读写,可直接使用本地文件系统. 不适合:与关系型数据 ...
- git 4种对象的理解
git中有四种基本对象类型,可以说Git的所有操作都是通过这四种对象完成的.下图是<Git版本控制管理>中文第二版的原话,顺便吐槽一下,这本书真的翻译的一般.. 下面说下我的理解吧,首先b ...
- C#中的里氏替换原则
里氏转换原则 子类可以赋值给父类对象 父类对象可以强制转化为对应的子类对象 里氏替换原则直观理解就是"子类是父类",反过来就说不通了. 就像男人是人对的,但人是男人就不对了. 这样 ...
- nginx 做前端代理时proxy参数配置
1.后台可登录: proxy_connect_timeout 300s; proxy_send_timeout ; proxy_read_timeout ; proxy_buffer_size 256 ...
- mysql临时表空间暴涨
(此文刚好遇到转载记录) 一.内部临时表使用 在某些情况下,服务器在处理语句时创建内部临时表,而用户无法直接控制临时表何时发生,完全有MySQL内部自行决定. MySQL在以下几种情况会创建临时表: ...
- PATHINFO模式是thinkphp特有的吗?
pathinfo当然不是某个框架特有的,pathinfo严格上讲是HTTP服务器提供的一个预定义变量,在许多的框架中有一个重要的组件叫做路由器,这个组件可以通过使用pathinfo来实现. 考虑以下代 ...