Django之models.py
模型是写一个数据库驱动的web的第一步,也就是数据库结构设计和附加的其它元数据
也就是说你的models.py决定了你数据库的长相。
下面时自己在完成todolist项目时用的一部分models,在这里记一下,以备后查
定义的方法为:
from django.db import models
#用户信息表
class UserInfo(models.Model):name = models.CharField(max_length=255,verbose_name='姓名')Phone = models.BooleanField(default=False,verbose_name='联系方式')gender = models.CharField(max_length=6,choices=(('male',''男),('female','女')),default='female',verbose_name='性别')class Meta:verbose_name = '用户信息'verbose_name_plural = verbose_name #指定模型的复数形式是什么,如果不指定Django会自动在模型名称后加一个’s’
#每一位用户的todo列表
class UserTodo(models.Model):todo = models.CharField(max_length,verbose_name='todo信息')user = model.ForeignKey(UserInfo,ondelete=models.CASCADE)created_time = model.DateTimeField(default=datetime.now(),verbose_name='创建时间')class Meta:verbose_name='todo表'verbose_name_plural = verbose_name
查官方文档
Field的选项有:
- null :用法model.**Field(null=True(False)),如果是True,Django则会在数据库中存储空的值,默认为False;
- blank:用法model.**Field(blank=True(False)),如果是True,Django则会在数据库中存储内容为空的值(注意与null的区别,null是在数据库的角度),默认为False;
- choices:用法model.**Field(choices=(('male','男'),('female','女'))),choices的对象应为可迭代的,例如列表或者元组。故名思意,如果给出choices,则会在表单中给出选项可以进行选择;
- default:用法model.**Field(default=***),给这个filed设置默认值,当callable,则每创建一个新的对象,这个default就会被调用一次
- verbose_name:用法model.**Field(verbose='人类可读的数据库的列名')
- ......
Field的类model.**Field(一直纠结的地方):
- AutoField:若指定数据库则会自动根据可用ID创建一个InterField 的自增的对象,一般不需要指定;
- BigAutoField:与AutoField一样,不过数字范围更大,从1到9223372036854775807;
- BigIntegerField:与IntegerField 类似,用来存储整型数据,不过也是范围更大,从-9223372036854775808到9223372036854775807;
- BinaryField:存储原始二进制数据的字段,只接受字节的指定
- BooleanField:多用在CheckboxInput中,存储True或False,若接受null 可以用NullBooleanField
- CharField:用来存储字符串,大小字符串兼收不误,若想要存储十分大量的文本,可以用TextField;CharField默认匹配的表单组件是TextInput;注意它有一个特殊的参数:max_length 用来限定存储字符的最长长度,在存储时,Django和数据库都会进行验证长度是否满足要求。
- DateField:用来存储日期,额外的参数有:auto_now,auto_now_add
- DateTimeField:用来存储日期和时间,额外的参数有:auto_now,auto_now_add
Django之models.py相关推荐
- 第三百零九节,Django框架,models.py模块,数据库操作——F和Q()运算符:|或者、并且——queryset对象序列化...
第三百零九节,Django框架,models.py模块,数据库操作--F()和Q()运算符:|或者.&并且 F()可以将数据库里的数字类型的数据,转换为可以数字类型 首先要导入 from dj ...
- Django中models模型(操作数据库)
ORM 自己创建数据库 连接数据库 Django操作表 数据库操作 新建 删除 获取数据 实例:用户管理 Django开发操作数据库更简单,内部提供了ORM框架 ORM的流程 ORM ORM,全称 O ...
- Django model层 mysql_Django模型层(models.py)之模型创建
Django数据库操作是十分重要的内容,这两天简单学习了数据库的操作,这里做个总结. 1.ORM简介 详细介绍可以参考这篇博客: 简单的来说,ORM就是对象-关系-映射.它实现了数据模型与数据库的解耦 ...
- django 使用原生SQL语句反向生成MODELS.PY中的表结构
在一次工作中,有这么一个问题,就是要导入的数据字段不确定,但是还想使用django的ORM来对数据进行操作.. 琢磨了许久,弄个不完善的方案,但功能是能实现的,主要是思路.废话不多说了,丑陋的展示一下 ...
- Django框架view.py,models.py,urls.py用法及调用关系的个人理解
一.框架最让人头疼的问题 利用框架来编写程序,会大大降低编写难度,但是如果不了解框架的调用关系及各个文件的作用,在遇到error时往往会很头疼. 以前曾经编写过Android程序,网络上对Androi ...
- Django学习笔记-models.py操作数据库
1.在settings.py的 INSTALLED_APPS 添加项目名称 INSTALLED_APPS = ['django.contrib.admin','django.contrib.auth' ...
- Django模型层(models.py)之多表操作
添加表记录 一对多: # 方式1:publish_obj = Publish.objects.get(id=1)Book.objects.create(name='2号图书',price=200,pu ...
- django的数据库名字和models.py中类名的对应关系
如果app的名字是users users/models.py中如果是一个这样的类 class UserProfile(AbstractUser):GENDER_CHOICE = (('male', ' ...
- django避免写models.py办法
用datagrip想建立表格,datagrip中submit以后 在项目目录下执行此命令 python manage.py inspectdb > fenye/models.py(前提是已经正确 ...
最新文章
- Spring Cloud Sleuth 进阶实战
- 基于单目视觉的智能车辆视觉导航系统设计
- Eclipse配置Tomcat和JDK方法
- SQLMAP使用笔记
- 什么是区块链预言机(BlockChain Oracle)
- MySQL数据库事务中的行级锁,表级锁,页级锁
- php用到的mysql语句_PHP中常用到的一些MySQL语句_php
- 计算机组成原理—地址码
- fer2013人脸表情数据实践
- Java Map 集合实现类
- 自动控制原理实验验优报告(资料区附matlab代码)
- 抖音超火的罗马时钟html代码,最近抖音上挺火的圆形文字时钟
- Win 10 版NVIDIA GeForce GTX 1060显卡驱动的下载及飞桨(Paddle)的安装
- 电视制式以及伴音载频制式详解
- 深度剖析:针对深度学习的GPU共享
- 关闭 mysql redo_MySQL redo log总结
- Android外部存储设备管理——vold挂载大容量存储设备
- [资源分享][Unity][人物模型][动作]一些人物模型以及动作的分享
- 电脑使用者的眼睛保护
- 组播PIM-原理介绍+报文分析+配置示例