python - django model是用get还filter
问题描述
如下面代码,会根据实例ID获取实例对象,大家知道get的时候如果id不存在会出现异常,但是filter不会。那么,请问大家,像类似这种情况是用get然后处理异常要好呢,还是filter来做好呢,哪种更规范?
def get_city_image(self, instance):if instance.city_id: try:city_image = City.objects.get(id=instance.city_id).image.url# city_image = City.objects.filter(id=instance.city_id).last().image.url except Exception, e:city_image = Noneelse: city_image = Nonereturn city_image
问题解答
回答1:def get_city_image(self, instance): try:city_image = City.objects.get(id=instance.city_id).image.url except City.DoesNotExist:#捕获City不存在的异常, 抛出异常或是自己处理city_image = None return city_image回答2:
框架选择设计问题,django 是扔异常,别的框架直接返回None,看你喜欢那种,我不喜欢这种直接扔异常,直接补一个自己的方法就行了
参考链接: django 扩展/补丁 QuerySet
回答3:用filter.first 效率是一样的,并且不会抛异常
相关文章:
1. css - chrome下a标签嵌套img 显示会多个小箭头?2. sql语句 - mysql中关联表查询问题3. javascript - vscode alt+shift+f 格式化js代码,通不过eslint的代码风格检查怎么办。。。4. javascript - 求解答:实例对象调用constructor,此时constructor内的this的指向?5. javascript - iframe 为什么加载网页的时候滚动条这样显示?6. javascript - 原生canvas中如何获取到触摸事件的canvas内坐标?7. javascript - 如何将一个div始终固定在某个位置;无论屏幕和分辨率怎么变化;div位置始终不变8. javascript - 有什么比较好的网页版shell前端组件?9. html - vue项目中用到了elementUI问题10. mysql updtae追加数据sql语句
