【原创】Django中Model的Get和Filter区别

发布于 2019-01-11  454 次阅读


Django的日常使用中,我们会用到Model中的get和filter方法,今天说说两者的区别。

为了更好地说明问题,先定义一个Model

class User(models.Model):
    name = models.CharField('姓名',max_length=20,default='')
    age = models.CharField('年龄',max_length=20,default='')

模拟数据:

User数据:
id    name    age
1    zhangsan    17
2    lisi    17

一、先说说Django的get用法:

如果我们想要获取到一个name是zhangsan的User:

user = User.objects.get(name="zhangsan")

这时会获取到一个name是zhangsan的用户对象

如果我想要获取到一个age是17的User:

user = User.objects.get(age="17")

这时就报错了,因为Get方法:只能获取到唯一值的对象结果。如果匹配到好几个对象,就会报错;如果一个也匹配不到,也会报错。

二、再说说Django的filter用法:

如果我们想要获取到一个name是zhangsan的User:

user = User.objects.filter(name="zhangsan")

此时会获取到一个Queryset对象,第一个对象是zhangsan的User对象,此对象跟get获取到的zhangsan是一样的

如果我们要获取到一个age是17的User:

user = User.objects.filter(age="17")

测试还是获取到一个Queryset对象,里边两个对象,一个是zhangsan的User对象,一个是lisi的User对象

如果我们获取一个不存在的对象时,会返回一个空的[],但是这个不是一个list,不能以list的操作方法进行

三、总结

两者的使用和区别,基本都讲清楚了,我最后想说一下我的想法:

如果有时我们不能确定数据库里是否有你要查询的数据时,我更多的建议大家使用filter方法,而不是用get。因为get可能会在查询不到数据时,代码就会报错,导致程序停止运行。

如果数据是确定存在的,通过get能够更准确的获取到你要的数据对象。

欢迎大家关注我的公众号: