模型是写一个数据库驱动的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相关推荐

  1. 第三百零九节,Django框架,models.py模块,数据库操作——F和Q()运算符:|或者、并且——queryset对象序列化...

    第三百零九节,Django框架,models.py模块,数据库操作--F()和Q()运算符:|或者.&并且 F()可以将数据库里的数字类型的数据,转换为可以数字类型 首先要导入 from dj ...

  2. Django中models模型(操作数据库)

    ORM 自己创建数据库 连接数据库 Django操作表 数据库操作 新建 删除 获取数据 实例:用户管理 Django开发操作数据库更简单,内部提供了ORM框架 ORM的流程 ORM ORM,全称 O ...

  3. Django model层 mysql_Django模型层(models.py)之模型创建

    Django数据库操作是十分重要的内容,这两天简单学习了数据库的操作,这里做个总结. 1.ORM简介 详细介绍可以参考这篇博客: 简单的来说,ORM就是对象-关系-映射.它实现了数据模型与数据库的解耦 ...

  4. django 使用原生SQL语句反向生成MODELS.PY中的表结构

    在一次工作中,有这么一个问题,就是要导入的数据字段不确定,但是还想使用django的ORM来对数据进行操作.. 琢磨了许久,弄个不完善的方案,但功能是能实现的,主要是思路.废话不多说了,丑陋的展示一下 ...

  5. Django框架view.py,models.py,urls.py用法及调用关系的个人理解

    一.框架最让人头疼的问题 利用框架来编写程序,会大大降低编写难度,但是如果不了解框架的调用关系及各个文件的作用,在遇到error时往往会很头疼. 以前曾经编写过Android程序,网络上对Androi ...

  6. Django学习笔记-models.py操作数据库

    1.在settings.py的 INSTALLED_APPS 添加项目名称 INSTALLED_APPS = ['django.contrib.admin','django.contrib.auth' ...

  7. Django模型层(models.py)之多表操作

    添加表记录 一对多: # 方式1:publish_obj = Publish.objects.get(id=1)Book.objects.create(name='2号图书',price=200,pu ...

  8. django的数据库名字和models.py中类名的对应关系

    如果app的名字是users users/models.py中如果是一个这样的类 class UserProfile(AbstractUser):GENDER_CHOICE = (('male', ' ...

  9. django避免写models.py办法

    用datagrip想建立表格,datagrip中submit以后 在项目目录下执行此命令 python manage.py inspectdb > fenye/models.py(前提是已经正确 ...

最新文章

  1. Spring Cloud Sleuth 进阶实战
  2. 基于单目视觉的智能车辆视觉导航系统设计
  3. Eclipse配置Tomcat和JDK方法
  4. SQLMAP使用笔记
  5. 什么是区块链预言机(BlockChain Oracle)
  6. MySQL数据库事务中的行级锁,表级锁,页级锁
  7. php用到的mysql语句_PHP中常用到的一些MySQL语句_php
  8. 计算机组成原理—地址码
  9. fer2013人脸表情数据实践
  10. Java Map 集合实现类
  11. 自动控制原理实验验优报告(资料区附matlab代码)
  12. 抖音超火的罗马时钟html代码,最近抖音上挺火的圆形文字时钟
  13. Win 10 版NVIDIA GeForce GTX 1060显卡驱动的下载及飞桨(Paddle)的安装
  14. 电视制式以及伴音载频制式详解
  15. 深度剖析:针对深度学习的GPU共享
  16. 关闭 mysql redo_MySQL redo log总结
  17. Android外部存储设备管理——vold挂载大容量存储设备
  18. [资源分享][Unity][人物模型][动作]一些人物模型以及动作的分享
  19. 电脑使用者的眼睛保护
  20. 组播PIM-原理介绍+报文分析+配置示例

热门文章

  1. 手Q支付(QQ钱包)
  2. mysql二级考试范围_计算机二级MySQL考试内容大纲
  3. FaceNet 读书笔记
  4. thinkphp项目中think文件夹所在的目录use think\Request;------潘万丁
  5. 购买弹性云服务器怎么部署网站,购买后怎么部署自己的云服务器
  6. LeCo-3. 无重复字符的最长子串
  7. 金融日 | 看金融机构数据安全建设典型案例
  8. 06-SparkSQL
  9. VB通过洗牌算法生成随机数ID
  10. 阿里云服务器快速购买、自定义购买、通过活动购买图文教程