Django默认ORM(三):基本字段类型和参数
基本字段类型
字段:大致分为 字符串、数字、时间、二进制、自增(primary_key=True)等类 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 对于参数,auto_now = True 则每次更新都会更新这个时间;auto_now_add 则只是第一次创建添加,之后的更新不再改变。 6、models.DateTimeField 日期类型 datetime 同DateField的参数 7、models.Decimal 十进制小数类型 = decimal 必须指定整数位max_digits和小数位decimal_places 8、models.EmailField 字符串类型(正则表达式邮箱) =varchar 对字符串进行正则表达式 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.IPAddressField 字符串类型(ip4正则表达式)(已弃用) 13、models.GenericIPAddressField 字符串类型(ip4和ip6是可选的) 参数protocol可以是:both、ipv4、ipv6 验证时,会根据设置报错 14、models.NullBooleanField 允许为空的布尔类型 15、models.PositiveIntegerFiel 正Integer 16、models.PositiveSmallIntegerField 正smallInteger 17、models.SlugField 减号、下划线、字母、数字 18、models.SmallIntegerField 数字 数据库中的字段有:tinyint、smallint、int、bigint 19、models.TextField 字符串=longtext 20、models.TimeField 时间 HH:MM[:ss[.uuuuuu]] 21、models.URLField 字符串,地址正则表达式 22、models.BinaryField 二进制 23、models.ImageField 图片 24、models.FilePathField 文件
admin的字段参数
choices #1、django admin中显示下拉框;2、避免连表查询 # 数据库只存1、2、3,后面的信息存在内存里。 user_type_choices = ( (1, '超级用户'), (2, '普通用户'), (3, '普普通用户'), ) user_type_id = models.IntegerField(choices=user_type_choices,default=1) blank # django admin是否可以为空 verbose_name # django admin显示字段中文 editable # django admin是否可以被编辑 error_messages # 错误信息 # error_messages={"required":"密码不能为空",} # 注意必须有逗号 help_text # django admin提示 validators # django form ,自定义错误信息 python manage.py createsuperuser # 创建 Django 用户,根据提示创建用户,密码,邮箱 127.0.0.1/admin 进入
其他正常参数:
正常一般参数使用: null # 是否可以为空 null=True default # 默认值 primary_key # 主键 db_column # 列名 db_index # 索引(db_index=True) unique # 唯一索引(unique=True) unique_for_date # 只对日期索引 unique_for_month # 只对月份索引 unique_for_year # 只对年做索引 auto_now # 创建时,自动生成时间 auto_now_add # 更新时,自动更新为当前时间 # 更新时间不支持这种: obj = UserGroup.objects.filter(id=1).update(caption='CEO') 你需要这样写: obj = UserGroup.objects.filter(id=1).first() # 自动更新时间需要这样写 obj.caption = "CEO" obj.save()