码迷,mamicode.com
首页 > 数据库 > 详细

Django视图,与数据库交互并返回数据

时间:2017-09-09 17:14:35      阅读:187      评论:0      收藏:0      [点我收藏+]

标签:inter   方法   网上   bsp   http   load   es2017   color   对象   

环境:python 2.7.13  数据库:sqlite3(Django自带)  

在学习Django的时候,遇到了困难。大概就是取到数据库数据后一直不能转成json数据。最后终于自己琢磨解决了。

要点就是在通过Django API与sqlite数据库做交互时,要看清楚返回的对象是什么类型。

 

首先,与数据库做交互,简单来说,无非就是增删改查。首先来说一说“查”,以后会陆续更新其他

 

在网上查了几种比较常用的方法

models.UserInfo.objects.all()
models.UserInfo.objects.all().values(‘user‘)    #只取user列
models.UserInfo.objects.all().values_list(‘id‘,‘user‘)    #取出id和user列,并生成一个列表
models.UserInfo.objects.get(id=1)
models.UserInfo.objects.get(user=‘yangmv‘)
 
当采用models.Interface.objects.all()来查询的时候,笔者源代码如下
def returndata(request):
    info = models.Interface.objects.all()
    isdict = serializers.serialize(json, info)
    return HttpResponse(isdict, content_type="application/json")

此时通过打断点可以看到info的类型为QuerySet

技术分享

此时我们用serializers.serialize(‘json‘, info),来解析转换即可,最后通过HttpResponse正常返回

 

当采用models.Interface.objects.get(payload=123456)来查询的时候,笔者源代码如下

def returndata(request):
    info = models.Interface.objects.get(payload=123456)
    response_data = {}
    isdict = model_to_dict(info)
    response_data["resultcode"] = 0
    response_data["message"] = isdict
    return HttpResponse(JsonResponse(response_data), content_type="application/json")

此时通过打断点可以看到info的类型为Interface

技术分享

此时我们用model_to_dict(info),来解析转换即可,最后通过HttpResponse正常返回

 

 

Django视图,与数据库交互并返回数据

标签:inter   方法   网上   bsp   http   load   es2017   color   对象   

原文地址:http://www.cnblogs.com/semishigure/p/7498608.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!