1. django 模型models 常用字段

        
1、models.AutoField  
  • 自增列 = int(11)
  • 如果没有的话,默认会生成一个名称为 id 的列
  • 如果要显式的自定义一个自增列,必须设置primary_key=True。
 
2、models.CharField  
  • 字符串字段
  •   必须设置max_length参数
 
3、models.BooleanField  
  • 布尔类型=tinyint(1)
  •   不能为空,可添加Blank=True
 
4、models.ComaSeparatedIntegerField  
  • 用逗号分割的数字=varchar
  •   继承CharField,所以必须 max_lenght 参数
 
5、models.DateField
  • 日期类型 date
  •   DateField.auto_now:保存时自动设置该字段为现在日期,最后修改日期
  • DateField.auto_now_add:当该对象第一次被创建是自动设置该字段为现在日期,创建日期。
 
6、models.DateTimeField  
  • 日期时间类型 datetime
  •   同DateField的参数
 
7、models.Decimal  
  • 十进制小数类型 = decimal
  • DecimalField.max_digits:数字中允许的最大位数
  • DecimalField.decimal_places:存储的十进制位数
 
8、models.EmailField  
  •   一个带有检查 Email 合法性的 CharField
 
9、models.FloatField  
  • 浮点类型 = double
 
10、models.IntegerField  
  • 整形
 
11、models.BigIntegerField  
  • 长整形
  •   integer_field_ranges = {
    'SmallIntegerField': (-32768, 32767),
    'IntegerField': (-2147483648, 2147483647),
    'BigIntegerField': (-9223372036854775808, 9223372036854775807),
    'PositiveSmallIntegerField': (0, 32767),
    'PositiveIntegerField': (0, 2147483647),
  }
 
12、models.GenericIPAddressField  
  • 一个带有检查 IP地址合法性的 CharField
 
13、models.NullBooleanField  
  • 允许为空的布尔类型
 
14、models.PositiveIntegerFiel  
  • 正整数
 
15、models.PositiveSmallIntegerField  
  • 正smallInteger
 
16、models.SlugField  
  • 减号、下划线、字母、数字
 
17、models.SmallIntegerField  
  • 数字
  •   数据库中的字段有:tinyint、smallint、int、bigint
 
18、models.TextField  
  • 大文本。默认对应的form标签是textarea。
 
19、models.TimeField  
  • 时间 HH:MM[:ss[.uuuuuu]]
 
20、models.URLField  
  • 一个带有URL合法性校验的CharField。
 
21、models.BinaryField  
  • 二进制
  • 存储二进制数据。不能使用filter函数获得QuerySet。
 
22、models.ImageField   
  • 图片
  • ImageField.height_field、ImageField.width_field:如果提供这两个参数,则图片将按提供的高度和宽度规格保存。
  • 该字段要求 Python Imaging 库Pillow。
  • 会检查上传的对象是否是一个合法图片。
 
23、models.FileField(upload_to=None[, max_length=100, ** options])
  • 文件
  • FileField.upload_to:一个用于保存上传文件的本地文件系统路径,该路径由 MEDIA_ROOT 中设置
  • 这个字段不能设置primary_key和unique选项.在数据库中存储类型是varchar,默认最大长度为100
 
24、models.FilePathField(path=None[, math=None, recursive=False, max_length=100, **options])
  • FilePathField.path:文件的绝对路径,必填
  • FilePathField.match:用于过滤路径下文件名的正则表达式,该表达式将用在文件名上(不包括路径)。
  • FilePathField.recursive:True 或 False,默认为 False,指定是否应包括所有子目录的路径。
  • 例如:FilePathField(path="/home/images", match="foo.*", recursive=True)

将匹配“/home/images/foo.gif”但不匹配“/home/images/foo/bar.gif”


2. django 模型models 字段常用参数
 
1、null
  • 如果是True,Django会在数据库中将此字段的值置为NULL,默认值是False
 
2、blank
  •   如果为True时django的 Admin 中添加数据时可允许空值,可以不填。如果为False则必须填。默认是False。
  • null纯粹是与数据库有关系的。而blank是与页面必填项验证有关的
 
3、primary_key = False
  •    主键,对AutoField设置主键后,就会代替原来的自增 id 列
 
4、auto_now 和 auto_now_add
  •   auto_now   自动创建---无论添加或修改,都是当前操作的时间
  •   auto_now_add  自动创建---永远是创建时的时间
 
5、choices
  • 一个二维的元组被用作choices,如果这样定义,Django会select box代替普通的文本框,
  • 并且限定choices的值是元组中的值
  • GENDER_CHOICE = (
  • (u'M', u'Male'),
  • (u'F', u'Female'),
  • )
  • gender = models.CharField(max_length=2,choices = GENDER_CHOICE)
 
6、max_length
  • 字段长度
 
7、default
  • 默认值
 
8、verbose_name  
  • Admin中字段的显示名称,如果不设置该参数时,则与属性名。
 
9、db_column  
  • 数据库中的字段名称
 
10、unique=True  
  • 不允许重复
 
11、db_index = True  
  • 数据库索引
 
12、editable=True  
  • 在Admin里是否可编辑
 
13、error_messages=None  
  • 错误提示
 
14、auto_created=False  
  • 自动创建
 
15、help_text  
  • 在Admin中提示帮助信息
 
16、validators=[]
  • 验证器
 
17、upload-to
  • 文件上传时的保存上传文件的目录

models.py

        # -*- coding: utf-8 -*-
from __future__ import unicode_literals

from django.db import models

class UserInfo(models.Model):

userName = models.CharField(max_length=30)  #用户名

passWord = models.CharField(max_length=30)  #密码

gendle = models.BooleanField()  #性别

birthday = models.DateField()   #出生日期

weigth = models.FloatField()    #体重

heigth = models.IntegerField()  #身高

email = models.EmailField()     #邮箱

host = models.GenericIPAddressField()  #IP地址

introduce = models.TextField()  #个人简介

blog = models.URLField()        #博客地址

photo = models.ImageField()     #照片

CV = models.FilePathField()     #个人简历文件

createDate = models.DateTimeField()     #帐号申请时间

执行结果:

                

 

3.常见异常处理

    1) 
               ERRORS:

               web.UserInfo.photo: (fields.E210) Cannot use ImageField because Pillow is not installed.
               HINT: Get Pillow at https://pypi.python.org/pypi/Pillow or run command "pip install Pillow".
 
       原因:      

       这是因为使用了ImageField()字段,该字段是直接在数据库中存储图片的,数据库中实际存储时要使用python的Pillow模块对图片进行处理后才能存储进去。因此因需使用pip install Pillow 安装该模块即可解决该报错。

2)

             ERRORS:

                在执行python manage.py makemigrations 时需要手动选择处理方法:
                You are trying to add a non-nullable field 'CV' to userinfo without a default; we can't do that (the database                     needs something to populate existing rows).
Please select a fix:

1) Provide a one-off default now (will be set on all existing rows with a null value for this column)

2) Quit, and let me add a default in models.py

Select an option: 1

Please enter the default value now, as valid Python

The datetime and django.utils.timezone modules are available, so you can do e.g. timezone.now

Type 'exit' to exit this prompt

>>> timezone.now

     原因:

             这是因为UserInfo数据表中已经有了"userName"和"passWord" 这两个字段,当在新增字段时就会出现这种Warning。是由于django框架在生成SQL语句时发现数据表不为空,担心新增不为Null的字段添加到该表中时,表中以前的数据行在填充这些字段时需要填充的值不明确,所以才会询问用户处理方式。
            选1,则会在已存在行中添加null,选2,则会要求在models.py中添加默认值。
            在models.py中设置默认值的方法:
                     host = models.GenericIPAddressField(default = '127.0.0.1')
 

3)  执行python makemigrations正常,但是执行python migrate 报错,之后再执行无法生效的处理办法

 

django 模型models的更多相关文章

  1. 【Python】django模型models的外键关联使用

    Python 2.7.10,django 1.8.6 外键关联:http://www.bubuko.com/infodetail-618303.html 字段属性:http://www.cnblogs ...

  2. django模型models.py文件内容理解

    首先,要理解这句话:模型是你的数据的唯一的.权威的信息源.它包含你所存储数据的必要字段和行为.通常,每个模型对应数据库中唯一的一张表 基础:每个模型都是django.db.models.Model的一 ...

  3. Django 1.10 中文文档------3.2.1 模型Models

    3.2.1 models模型 通常一个模型映射一张单独的数据表. 基本概念: 每个model都是django.db.models.Model的子类 model的每个属性代表数据表的某一列 Django ...

  4. django的models模型类的常用数据类型和选项

    django框架的models模块ORM框架,能够让我们通过编写类的方式,帮助我们自动生成数据库表. 生成的数据库表名为 应用模块名称_类名 数据库表中字段名 如果我们没有在参数中指定,就是我们写的类 ...

  5. Django基础之模型(models)层(上)

    目录 Django基础之模型(models)层 单表查询 必知必会13条 神奇的双下划线查询 多表查询 外键的字段的增删改查 表与表之间的关联查询 基于双下划线的跨表查询(连表查询) 补充知识 Dja ...

  6. Django中文文档-模型Models(二):Meta选项、模型属性、模型方法

    元数据(Meta)选项 使用内部的class Meta 定义模型的元数据,例如: from django.db import models class Ox(models.Model): horn_l ...

  7. Django模型类Meta元数据详解

    转自:https://my.oschina.net/liuyuantao/blog/751337 简介 使用内部的class Meta 定义模型的元数据,例如: from django.db impo ...

  8. Django模型的Field Types总结

    转:http://blog.csdn.net/devil_2009/article/details/41735611 Field Types 常用参数: null 如果设置为 True , Djang ...

  9. 【Django】--Models 和ORM以及admin配置

    Models 数据库的配置 1    django默认支持sqlite,mysql, oracle,postgresql数据库 <1>sqlite django默认使用sqlite的数据库 ...

随机推荐

  1. PHP7.0-PHP7.3新特性与变更

    到目前为止,PHP7发布已经升级到7.3,本文来总结一下每个版本的变更与新特性 PHP7.0 1. 组合比较符 (<=>) 组合比较符号用于比较两个表达式.当$a小于.等于或大于$b时它分 ...

  2. 网络流学习(转载自ssw 的博客)

    众所周知,网络流是探究网络上运输的一种图论分支.但是大多数人在第一次接触这个题时都有些畏惧感(比如说我),大佬可以自信跳过.. 本文包括: 1.网络流的概念及基本性质 2.略谈 Edmonds-Kar ...

  3. LeetCode136.只出现一次的数字

    给定一个非空整数数组,除了某个元素只出现一次以外,其余每个元素均出现两次.找出那个只出现了一次的元素. 说明: 你的算法应该具有线性时间复杂度. 你可以不使用额外空间来实现吗? 示例 1: 输入: [ ...

  4. StringBuilder的常用方法

    转自:https://www.cnblogs.com/jack-Leo/p/6684447.html 在程序开发过程中,我们常常碰到字符串连接的情况,方便和直接的方式是通过"+"符 ...

  5. git版本回退

    场景1: 当你改乱了工作区某个文件的内容,修改后未执行git add和git commit,想直接丢弃工作区的修改时,用命令git checkout -- file. 场景2: 当你不但改乱了工作区某 ...

  6. Error:Failed to resolve: com.android.support.constraint:constraint-layout:1.0.2

    可以换个maven库: allprojects { repositories { jcenter() //maven { url "https://jitpack.io" } ma ...

  7. Linux下截取指定时间段日志并输出到指定文件

    sed -n '/2019-04-22 16:10:/,/2019-04-22 16:20:/p' log.log > bbb.txt

  8. vmware创建虚拟机不识别网卡

    今天在给虚拟机添加网卡的时候,出现了虚拟机不识别新加的网卡,很纳闷,连的一样的端口组,为什么新加的网卡识别不了呢 然后查看pci设备,发现网卡的驱动为 AMD 79C970 PCnet32- LANC ...

  9. 一本通 一笔画问题 洛谷P1636 Einstein学画画

    P1636 Einstein学画画 相信大家都玩过一笔画这种游戏吧,这其实算得上是我们能够接触到的比较常见的数学问题,有一个很知名的就是七桥问题 这个问题包括所有的一笔画问题都是在欧拉回路的涵盖范围内 ...

  10. 1068: [SCOI2007]压缩

    题解: 区间DP 考虑状态的设计: \(dp[i][j][0/1]\)表示原字符串的\(i-j\)区间有无在中间加\(M\).并且默认在\(i\)之前加入\(M\)压缩后的最小长度,显然有转移: \[ ...