Django模型(二)

知识点:

  1. 常用的查询
  2. Field的常用参数
  3. 常用的模型字段类型

常用的查询

获取所有记录:
User.objects.all()
获取第一条数据:
User.objects.first()
获取最后一条数据:
User.objects.last()
根据参数提供的条件获取过滤后的记录:
User.objects.filter(name='xiaoming')
注意:filter(**kwargs)方法:根据参数提供的提取条件,获取一个过滤后的QuerySet。
排除name等于xiaoming的记录:
User.objects.exclude(name='xiaoming')
获取一个记录对象:
User.objects.get(name='xiaoming')
注意:get返回的对象具有唯一性质,如果符合条件的对象有多个,则get报错!
对结果排序order_by:
User.objects.order_by('age')
多项排序:
User.objects.order_by('age','name')
逆向排序:
User.objects.order_by('-age')
将返回来的QuerySet中的Model转换为字典
User.objects.all().values()
获取当前查询到的数据的总数:
User.objects.count()

#查询对象的条件
查找对象的条件的意思是传给以上方法的一些参数。相当于是SQL语句中的where语句后面的条件,语法为字段名__规则,以下将对这些规则进行说明:
exact 相当于等于号:
User.objects.filter(name__exact='xiaoming')
iexact:跟exact,只是忽略大小写的匹配。
contains 包含:
User.objects.filter(name__contains='xiao')
icontains 跟contains,唯一不同是忽略大小写。
startwith 以什么开始:
User.objects.filter(name__startswith='xiao')
istartswith:同startswith,忽略大小写。
endswith:同startswith,以什么结尾。
iendswith:同istartswith,以什么结尾,忽略大小写。
in 成员所属:
User.objects.filter(age__in=[18,19,20])
gt 大于:
User.objects.filter(age__gt=20)
gte 大于等于:
User.objects.filter(age__gte=20)
lt 小于:
User.objects.filter(age__lt=20)
lte 小于等于:
User.objects.filter(age__lte=20)
range 区间:
User.objects.filter(age__range=(18,20))
isnull 判断是否为空:
User.objects.filter(country__isnull=True)
切片:
User.objects.all()[:2]
注意:不能使用负数作为切片。

Field的常用参数

primary_key: 指定是否为主键。

unique: 指定是否唯一。

null: 指定是否为空,默认为False。

blank: 等于True时form表单验证时可以为空,默认为False。

default: 设置默认值。

DateField.auto_now: 每次修改都会将当前时间更新进去,只有调用Model.save()方法才会调用,QuerySet.update方法将不会调用。这个参数只是Date和DateTime以及Time类才有的。

DateField.auto_now_add: 第一次添加进去,都会将当前时间设置进去。以后修改,不会修改这个值

常用的模型字段类型

  1. IntegerField : 整型,映射到数据库中的int类型。
  2. CharField: 字符类型,映射到数据库中的varchar类型,通过max_length指定最大长度。
  3. TextField: 文本类型,映射到数据库中的text类型。
  4. BooleanField: 布尔类型,映射到数据库中的tinyint类型,在使用的时候,传递True/False进去。如果要可以为空,则用NullBooleanField。
  5. DateField: 日期类型,没有时间。映射到数据库中是date类型,
    在使用的时候,可以设置DateField.auto_now每次保存对象时,自动设置该字段为当前时间。设置DateField.auto_now_add当对象第一次被创建时自动设置当前时间。
  6. DateTimeField: 日期时间类型。映射到数据库中的是datetime类型,
    在使用的时候,传递datetime.datetime()进去。

例子

class Ftest(models.Model):
    name = models.CharField(max_length=30)
    age = models.IntegerField()
    note = models.TextField()
    gender = models.BooleanField(default=True)
    create_time = models.DateField(auto_now_add=True)
    update_time = models.DateTimeField(auto_now=True)

你可能感兴趣的:(Django模型(二))