1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > 数据库数据转换成JSON格式实例详解

数据库数据转换成JSON格式实例详解

时间:2020-04-08 18:10:27

相关推荐

数据库数据转换成JSON格式实例详解

后端开发|Python教程

javascript,django-,JSON

后端开发-Python教程

最近打算搞一个自动化运维平台,所以在看Django的知识。

小京东5.0多商户源码,ubuntu上传文件超时,爬虫怎么下载库,黑马PHP课程,若知seolzw

在实际项目开发中,遇到一个小问题:前后端发生数据交互主流采用的是JSON。前端传数据到服务器端比较简单,稍微麻烦的是服务器端传JSON到前端。

植物大战僵尸外挂源码,vscode去掉换行符,ubuntu apt列表,改用tomcat归档版,北京鲲鹏 爬虫,php 三级返利,南京seo排名优化公司推荐lzw

首先数据是从数据库中获取的,Django默认使用的是ORM技术,但是作为一个运维人员,我其实比较反感这类抽象出来的API。因为尽管它对于开发人员来说,将数据库的表抽象成了一个对象,便于开发,不需要写SQL语句,但是这也是后期程序造成性能瓶颈的罪魁祸首(再做一次故障处理时,遇到一条70几行的SQL语句。。。。。),另外对于一个运维人员来说,纯SQL是基本能力,再次去学习ORM的语法,无形中又增加了学习成本。

网页一键生成php源码,vscode十大插件,bios支持ubuntu,tomcat7 log,新浪 爬虫 乱码,php 截取字符串 中文,seo技术新手入门引流,简约大气网站源码,软件开发网站模板lzw

不管怎么说,这次的主题是将从数据库获取数据转换成JSON,下面会将用ORM和SQL两种方式都拿出来分享。

1.采用Django Model层,ORM技术 转换成JSON格式

1 def getdata(request):2 # 使用ORM3 # all()返回的是QuerySet 数据类型;values()返回的是ValuesQuerySet 数据类型4 data = models.VM.objects.values(id, ip, host, username)5 data = serializers.serialize("json", tomcats)6 return JsonResponse(list(data), safe=False)

2.完全弃用Django Model层,纯SQL 转换成JSON格式

1 def getdata(request):2 # 使用SQL3with connection.cursor() as cursor:4 cursor.execute(select id, machine, tomcathome, ipaddress, description from tomcatData)5 data = dictfetchall(cursor)6return JsonResponse(data, safe=False, json_dumps_params={ensure_ascii: False})

JsonResponse 对象:

classJsonResponse(data, encoder=DjangoJSONEncoder, safe=True, json_dumps_params=None,**kwargs)

这个类是HttpRespon的子类,它主要和父类的区别在于:

1.它的默认Content-Type 被设置为: application/json

2.第一个参数,data应该是一个字典类型,当 safe 这个参数被设置为:False ,那data可以填入任何能被转换为JSON格式的对象,比如list, tuple, set。 默认的safe 参数是 True. 如果你传入的data数据类型不是字典类型,那么它就会抛出 TypeError的异常。

3.json_dumps_params参数是一个字典,它将调用json.dumps()方法并将字典中的参数传入给该方法。

通过以上的解释,上面两个方法的JsonResponse里面传入的参数就很清晰明了。

这样数据就会以JSON格式传入到前端,前端就能用AJAX获取到,并进行处理或者展示了。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。