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
如果我们想要获取到一个name是zhangsan的User:
user = User.objects.get(name="zhangsan")
这时会获取到一个name是zhangsan的用户对象
如果我想要获取到一个age是17的User:
user = User.objects.get(age="17")
这时就报错了,因为Get方法:只能获取到唯一值的对象结果。如果匹配到好几个对象,就会报错;如果一个也匹配不到,也会报错。
如果我们想要获取到一个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能够更准确的获取到你要的数据对象。