解决:AttributeError: can't set attribute

报错代码如下:

File "./ga_web/lib/meta_data.py", line 94, in instance_list_ip_port
    return [x.get('ip')+':'+str(x.get('port')) for x in self.instance_list(filter)]
  File "./ga_web/lib/meta_data.py", line 82, in instance_list
    for d in instance_list:
  File "/usr/local/lib/python2.7/site-packages/Django-1.8.7-py2.7.egg/django/db/models/query.py", line 1312, in __iter__
    setattr(instance, column, values[pos])
AttributeError: can't set attribute

可以看到出错地方是在 迭代instance_list 对象的时候报错的。

sql = "select i.* ,i.business_id,b.name as business,i.owner as owner_id,u.name as owner from instance i " \
              "left join business b on i.business_id=b.id left join user u on i.owner=u.id where 1=1 "
return Instance.objects.raw(sql)

而model Instance 有一个属性是“business”,sql语句的返回结果里也有个“business”字段,两个字段同名,导致数据从数据库查出来后,映射到model上正对上这个名称,所以instance_list(集合)中对象的“business”属性无法赋值或设置。解决办法是:要么重命名Instance中的“business”,要么修改sql语句中的“business”为其他名称,都可以解决。

这个报错其实很大众,可能大家出错的地方都不同,但最终根源问题还都是一样的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值