当前位置:首页 » 编程博文
开发技术指南» 文章正文
    引言: 如果你正在负责一个基于SQL Server的项目,或者你刚刚接触SQL Server,你都有可能要面临一些数据库性能的问题,这篇文章会为你提供一些有用的指导(其中大多数也可以用于其它的DBMS)。
 

 

    摘要:微软公布了visual studio 2005 express beta products公开下载 地址分别如下,累计大小约在510m左右: dotnet framework version 2.0 redistributable package beta 1 (x86) - 24mhttp://go.microsoft.com/fwlink/?linkid=30093&clcid=0x4......
 ·允许单一实例运行的方法    »显示摘要«
    摘要:1.基于对话框运行的情况,即只允许单一对话框运行的情况.使用互斥变量.在cwinapp::initinstance()的重载函数中,加入如下语句. handle hmutex = ::createmutex( null, true, m_pszappname ); if ( ::getlasterror() == error_already_exists ) return false;如果已经有实......


程序员必看:关于SQL Server的若干注意事项
如果你正在负责一个基于sql server的项目,或者你刚刚接触sql server,你都有可能要面临一些数据库性能的问题,这篇文章会为你提供一些有用的指导(其中大多数也可以用于其它的dbms).

在这里,我不打算介绍使用sql server的窍门,也不能提供一个包治百病的方案,我所做的是总结一些经验----关于如何形成一个好的设计.这些经验来自我过去几年中经受的教训,一直来,我看到许多同样的设计错误被一次又一次的重复. 【程序编程相关:今天写了第一个ASP.NET程序

【推荐阅读:软件的可维护性

【扩展信息:一个有意思的C++ trick (2)

你了解你用的工具吗?

不要轻视这一点,这是我在这篇文章中讲述的最关键的一条.也许你也看到有很多的sql server程序员没有掌握全部的t-sql命令与sql server提供的那些有用的工具.

“什么?我要浪费一个月的时间来学习那些我永远也不会用到的sql命令???”,你也许会这样说.对的,你不需要这样做.但是你应该用一个周末浏览所有的t-sql命令.在这里,你的任务是了解,将来,当你设计一个查询时,你会记起来:“对了,这里有一个命令可以完全实现我需要的功能”,于是,到msdn查看这个命令的确切语法.

不要使用游标

让我再重复一遍:不要使用游标.如果你想破坏整个系统的性能的话,它们倒是你最有效的首选办法.大多数的初学者都使用游标,而没有意识到它们对性能造成的影响.它们占用内存,还用它们那些不可思议的方式锁定表,另外,它们简直就像蜗牛.而最糟糕的是,它们可以使你的dba所能做的一切性能优化等于没做.不知你是否知道每执行一次fetch就等于执行一次select命令?这意味着如果你的游标有10000条记录,它将执行10000次select!如果你使用一组select.update或者delete来完成相应的工作,那将有效率的多.

初学者一般认为使用游标是一种比较熟悉与舒适的编程方式,可很不幸,这会导致糟糕的性能.显然,sql的总体目的是你要实现什么,而不是怎样实现.

我曾经用t-sql重写了一个基于游标的存储过程,那个表只有100,000条记录,原来的存储过程用了40分钟才执行完毕,而新的存储过程只用了10秒钟.在这里,我想你应该可以看到一个不称职的程序员究竟在干了什么!!!

我们可以写一个小程序来取得与处理数据并且更新数据库,这样做有时会更有效.记住:对于循环,t-sql无能为力.


...   下一页
 ·基类和子类的调用顺序(c#,java)    »显示摘要«
    摘要:现在关于oo的编程思想已经越来越被大家接受,但是大家对一些基础化的东西不是很熟悉,比如基类和子类的调用顺序。在这里我以c#为例给大家讲解一下对于一个下面一段代码 public class baseclass { public string a="baseclass" ; public baseclass() { a="初始化baseclass"; } } p......
» 本期热门文章:

©2000-2007 All Rights Reserved. 最佳浏览:1024X768 MSIE