Django的日常使用中,我们会用到Model中的get和filter方法,今天说说两者的区别。
为了更好地说明问题,先定义一个Model
1
2
3
4
|
class
User
(
models
.
Model
)
:
name
=
models
.
CharField
(
'姓名'
,
max_length
=
20
,
default
=
''
)
age
=
models
.
CharField
(
'年龄'
,
max_length
=
20
,
default
=
''
)
|
模拟数据:
1
2
3
4
5
|
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能够更准确的获取到你要的数据对象。
欢迎大家关注我的公众号: