SCPPO:解决MVC中Json传输数据量问题

【引言】

    之前自己对系统进行了熟悉,现在自己开始做新的模块!上先来这是个查询的功能:自己就捋思路,由于之前有类似的模块,实现起来就是照葫芦画瓢就行,主要就是sql语句的编写。功能不是很复杂就不再此赘述,不过在实现的时候遇到一个解决数据量的问题倒蛮有意思,在此与大家共享。          

【内容】

     基础:系统前台应用的是MVC3+Miniui!

 问题再现:

        (1)进入查询模块后会自动根据默认的条件查询出数据:


        (2)将查询日期提前一个月再次查询:

  SCPPO:解决MVC中Json传输数据量问题_第1张图片

        (3)Controller中的代码实现:

  SCPPO:解决MVC中Json传输数据量问题_第2张图片

  解决思路:

         通过上面描述问题出来了:查询3260条数据的时候没什么事儿,当查询数据量是29010条(用的查询sql语句在数据库中查)时就出问题!于是根据查询一条线的流程来判断问题有可能出在三个方面:一是后台查询出了问题;二是前台的Miniui承受不住这么大的数据显示三是Json转的时候出问题;有了思路马上就去实验解决问题:

        (1)设置断点进行单步调试排除后台查数据可能性:

SCPPO:解决MVC中Json传输数据量问题_第3张图片

        (2)上网上查Miniui中datagried显示最多限制没有查到具体数据,不过自己想既然应用这么广不到3万数据量都显示不了未免说不过去。于是将第二个猜测也暂时放一放!

        (3)直接在百度上搜上面问题展示中的报错信息—使用 JSON JavaScriptSerializer 进行序列化或反序列化时出错。字符串的长度超过了为 maxJsonLength 属性设置的值!果然有很多关于这个问题的解决方案:

         ①其中最为普遍的是:

           web.config的节点下添加:

<system.web.extensions>
    <scripting>
        <webServices>
            <jsonSerialization maxJsonLength="1024000000" />
        </webServices>
    </scripting>
</system.web.extensions>
         然而这样做之后并没有解决问题!

         ②继续探索:

         又找到一种解决方案,将代码改成这样:


         果然成功:

SCPPO:解决MVC中Json传输数据量问题_第4张图片

   

    分析&思考:虽然问题解决了,但是本着知其然,知其所以然的精神,又在网上查阅很多相关资料,对这个问题有了更加深入的理解:

    (1)为什么会有这个错?

     MVC框架内置的JsonResult代码中,在使用JavaScriptSerializer时,都是采用的默认值(参考:http://weblogs.asp.net/rashid/archive/2009/03/23/submitting-my-first-bug-after-asp-net-mvc-1-0-rtm-release.aspx)也就是MVC3自己带的Json的长度是有限的,需要修改一下长度!

    (2)修改为Int32.MaxValue它是多大那?自己设了个断点自己测了测(见下图)蛮大的够系统目前用的了!

SCPPO:解决MVC中Json传输数据量问题_第5张图片


     (3)把它的大小定义大了对性能有没有影响那?用系统反复做了测试加载3000多条数据的时候没有体现出差别。

     (4)那么为什么MVC自定义的时候把它定义小了?暂时没有找到很好的答案,自己个人猜测可能是考虑到占用空间大小吧!也希望有研究的朋友给予指导。      

【总结】

     不要把工作只当工作来做,怀揣着一颗求知的心去探索会发现有许多意想不到的收获!带着求真求知的欲望去解决问题,会发现原来这么有意思。

     相信自己会在探索求知的路上越走越远!

你可能感兴趣的:(SCPPO:解决MVC中Json传输数据量问题)