django中使用filter()(即对QuerySet操作)时踩的坑

代码伺候:

  先看如下代码:

例1:

         message = Message.objects.filter(pk=message_id2)

            message[0].id = message_id2
            message[0].content = content2
            message[0].message_type = message_type2
       print(message[0].id)
       print(message[0].content)

            message[0].save()

 

  可正常从QuerySet中读取数据,并打印出来,无误。可是无法将数据同步到数据库中。

  

      (1)all()返回的是QuerySet对象,程序并没有真的在数据库中执行SQL语句查询数据,但支持迭代,使用for循环可以获取数据。

         例如有Book表,其包含bookname,booknum两个属性, 如何使用Objects.all(),得到bookname和booknum的值

 (2)filter() 返回的是QuerySet对象,与all()相似,只是all()是查询所有数据,常用:filter表示‘ = ’,exclude表示’ != ’。

   (3)get()返回的是Model对象,类型为列表,说明使用get方法会直接执行sql语句获取数据。

  

  来看一个QuerySet对象:

  

 

 

  message = Message.objects.filter(pk=message_id2)

   message[0].content

  这样子确实可以读取到QuerySet中的数据,可是对QuerySet修改后的数据无法保存到数据库。

  例1中不要尝试通过message.save()的方式去同步数据到数据库,因为QuerySet不存在save()方法。

 

       正确写法如下: 

    要想同步到数据库中,需使用对象进行数据同步操作。

例2:

       message = Message.objects.filter(pk=message_id2).first()

           
            message.id = message_id2
            message.content = content2
            message.message_type = message_type2
            message.save()

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值