asp.net程序优化 尽量减少数据库连接操作

 更新时间:2012年05月02日 23:26:49   作者:  
最近做一个项目,做的比较郁闷,现在把项目经验总结在这里。项目的主要功能就是为第三方程序提供数据,并根据客户端的调用提供数据更新。我的程序属于服务端。服务端以站点形式部署,以Xml的数据格式输出
项目以我自己的设计编码完成,并整合测试。初始化数据时,问题出现了。刚开始体现在客户端接受数据很慢。测试环境环境下,数据库服务器部署在国外,网站部署在公司内部,而且我一直认为我的程序在数据库数据处理这里已经做了足够的优化,包括索引和主键已经做到了合理使用。综上所述,起初的速度问题一直没有引起我的关注。

然而最后问题的关键恰恰出在数据库连接查询方面,频繁查询导致数据初始化速度很慢。刚开始我采取的方法是即用即查:需要数据的时候就从数据库查,有比较多的单表查询返回单个字段的情况。假如我有大概3000条左右的数据集合,我循环取出其中的每一条,再从其它数据表里查询得到需要的字段,这样无故增加了3000多次数据库连接和关闭操作,当网络速度不理想时,程序速度就无法忍耐了。

坚持一条原则:尽量减少数据库连接操作。跟前端开发优化中的尽量少Http请求类似。

最终我采取的方案是将所需要的数据经过多个数据表统一放到一个List对象中,也就是放到内存中,在根据LINQ查询其中的每条数据,这样速度会快很多。这样似乎破坏力一个原则,之前我遵循的多表查询最好不要inner join3个以上的表,而这次出现了多次一个sql语句就inner join3个表以上的情况.虽然破坏了这个原则,但是相比速度极慢,连功能都实现不了的情况,显然inner join 也可以让人接受。

相关文章

  • C#/.NET读取或修改文件的创建时间及修改时间详解

    C#/.NET读取或修改文件的创建时间及修改时间详解

    这篇文章主要给大家介绍了关于C#/.NET读取或修改文件的创建时间及修改时间的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-08-08
  • IE和火狐中模仿Click事件及提交到新窗口总结(asp.net)

    IE和火狐中模仿Click事件及提交到新窗口总结(asp.net)

    在程序中去模拟一个click事件是可以的,如果这个click事件是来自<a>标签的,那如果希望得到单击按钮的效果,IE可以,但火狐无法实现
    2012-01-01
  • asp.net下url传递中文的解决方案

    asp.net下url传递中文的解决方案

    asp.net下url传递中文的解决方案...
    2007-04-04
  • asp.net Core中同名服务注册的实现代码

    asp.net Core中同名服务注册的实现代码

    Asp.Net Core中自带了容器,同时也可以使用AutoFac替换掉默认的容器,以下为两种方式同名服务的注册实现,对asp.net Core服务注册的实现代码感兴趣的朋友一起看看吧
    2022-03-03
  • C# 接口的隐式与显示实现及适应场景

    C# 接口的隐式与显示实现及适应场景

    以前在用到接口时,从来没注意到接口分为隐式实现与显示实现。昨天在浏览博客时看到相关内容,现在根据自己的理解记录一下,方便日后碰到的时候温习温习,需要的朋友可以了解下
    2012-12-12
  • ASP.NETWeb服务器验证控件如何使用

    ASP.NETWeb服务器验证控件如何使用

    这篇文章主要介绍了ASP.NETWeb服务器验证控件如何使用,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2015-09-09
  • asp.net关于onpropertychange和oninput事件实现代码

    asp.net关于onpropertychange和oninput事件实现代码

    文本框,数据列表,当在文本框中输入条件时需要实时刷新数据列表,而且需要满足多浏览器(IE6.0/7.0/8.0,FireFox,Opera,google chrome,Safair)其功能类似google的智能匹配,我是用asp.net实现的。
    2009-11-11
  • .Net整合Json实现REST服务客户端的方法详解

    .Net整合Json实现REST服务客户端的方法详解

    这篇文章主要给大家介绍了关于.Net整合Json实现REST服务客户端的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。
    2018-01-01
  • asp.net access添加返回自递增id的实现方法

    asp.net access添加返回自递增id的实现方法

    今天花了一点时间研究了这个问题,除此之外,还顺带研究了小孔子cms添加数据的过程,access添加返回自递增id也是从小孔子cms中研究出来的。
    2008-08-08
  • Asp.Net类型转换类(通用类)代码分享

    Asp.Net类型转换类(通用类)代码分享

    本文给大家分享两段代码,一段代码关于asp.net类型转换通用类的代码,第二段关于asp.net 页面数据验证通用类的实例代码,代码简单易懂,非常不错,感兴趣的朋友参考下吧
    2016-01-01

最新评论