仓酷云

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 2390|回复: 8
打印 上一主题 下一主题

[学习教程] MSSQL网页编程之SQL Server数据库优化计划

[复制链接]
小女巫 该用户已被删除
跳转到指定楼层
楼主
发表于 2015-1-16 22:24:32 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
Mysql的存储引擎接口定义良好。有兴趣的开发者可以通过阅读文档编写自己的存储引擎。server|数据|数据库|优化查询速率慢的缘故原由良多,罕见以下几种:
  1、没有索引大概没有效到索引(这是查询慢最多见的成绩,是程序计划的缺点)
  2、I/O吞吐量小,构成了瓶颈效应。
  3、没有创立盘算列招致查询不优化。
  4、内存不敷
  5、收集速率慢
  6、查询出的数据量过年夜(能够接纳屡次查询,其他的办法下降数据量)
  7、锁大概逝世锁(这也是查询慢最多见的成绩,是程序计划的缺点)
  8、sp_lock,sp_who,举动的用户检察,缘故原由是读写合作资本。
  9、前往了不用要的行和列
  10、查询语句欠好,没有优化
  能够经由过程以下办法来优化查询:
  1、把数据、日记、索引放到分歧的I/O设备上,增添读取速率,之前能够将Tempdb应放在RAID0上,SQL2000不在撑持。数据量(尺寸)越年夜,进步I/O越主要.
  2、纵向、横向支解表,削减表的尺寸(sp_spaceuse)
  3、晋级硬件
  4、依据查询前提,创建索引,优化索引、优化会见体例,限定了局集的数据量。注重添补因子要得当(最好是利用默许值0)。索引应当只管小,利用字节数小的列建索引好(参照索引的创立),不要对无限的几个值的字段建单一索引如性别字段
  5、进步网速;
  6、扩展服务器的内存,Windows2000和SQLserver2000能撑持4-8G的内存。设置假造内存:假造内存巨细应基于盘算机上并发运转的服务举行设置。运转MicrosoftSQLServer?2000时,可思索将假造内存巨细设置为盘算机中安装的物理内存的1.5倍。假如别的安装了全文检索功效,并盘算运转Microsoft搜刮服务以便实行全文索引和查询,可思索:将假造内存巨细设置为最少是盘算机中安装的物理内存的3倍。将SQLServermaxservermemory服务器设置选项设置为物理内存的1.5倍(假造内存巨细设置的一半)。
  7、增添服务器CPU个数;可是必需分明并行处置串行处置更必要资本比方内存。利用并行仍是串路程是MsSQL主动评价选择的。单个义务分化成多个义务,就能够在处置器上运转。比方延宕查询的排序、毗连、扫描和GROUPBY字句同时实行,SQLSERVER依据体系的负载情形决意最优的并行品级,庞大的必要损耗大批的CPU的查询最合适并行处置。可是更新操纵Update,Insert,Delete还不克不及并行处置。
  8、假如是利用like举行查询的话,复杂的利用index是不可的,可是全文索引,耗空间。likea%利用索引like%a不利用索援用like%a%查询时,查询耗时和字段值总长度成反比,以是不克不及用CHAR范例,而是VARCHAR。关于字段的值很长的建全文索引。
  9、DBServer和APPLicationServer分别;OLTP和OLAP分别
  10、散布式分区视图可用于完成数据库服务器团结体。团结体是一组分隔办理的服务器,但它们互相合作分管体系的处置负荷。这类经由过程分区数据构成数据库服务器团结体的机制可以扩展一组服务器,以撑持年夜型的多层Web站点的处置必要。有关更多信息,拜见计划团结数据库服务器。(参照SQL匡助文件分区视图)
  a、在完成分区视图之前,必需先程度分区表
  b、在创立成员表后,在每一个成员服务器上界说一个散布式分区视图,而且每一个视图具有不异的称号。如许,援用散布式分区视图名的查询能够在任何一个成员服务器上运转。体系操纵好像每一个成员服务器上都有一个原始表的复本一样,但实在每一个服务器上只要一个成员表和一个散布式分区视图。数据的地位对使用程序是通明的。
  11、重修索引DBCCREINDEX,DBCCINDEXDEFRAG,压缩数据和日记DBCCSHRINKDB,DBCCSHRINKFILE.设置主动压缩日记.关于年夜的数据库不要设置数据库主动增加,它会下降服务器的功能。在T-sql的写法上有很年夜的考究,上面列出罕见的要点:起首,DBMS处置查询企图的历程是如许的:
  1、查询语句的词法、语法反省
  2、将语句提交给DBMS的查询优化器
  3、优化器做代数优化和存取路径的优化
  4、由预编译模块天生查询计划
  5、然后在符合的工夫提交给体系处置实行
  6、最初将实行了局前往给用户其次,看一下SQLSERVER的数据寄存的布局:一个页面的巨细为8K(8060)字节,8个页面为一个盘区,依照B树寄存。
12、Commit和rollback的区分Rollback:回滚一切的事物。Commit:提交以后的事物.没有需要在静态SQL里写事物,假如要写请写在表面如:begintranexec(@s)committrans大概将静态SQL写成函数大概存储历程。

  13、在查询Select语句顶用Where字句限定前往的行数,制止表扫描,假如前往不用要的数据,华侈了服务器的I/O资本,减轻了收集的包袱下降功能。假如表很年夜,在表扫描的时代将表锁住,克制其他的连接会见表,成果严峻。
  14、SQL的正文声名对实行没有任何影响
  15、尽量不利用光标,它占用大批的资本。假如必要row-by-row地实行,只管接纳非光标手艺,如:在客户端轮回,用一时表,Table变量,用子查询,用Case语句等等。游标能够依照它所撑持的提取选项举行分类:只进必需依照从第一行到最初一行的按次提取行。FETCHNEXT是独一同意的提取操纵,也是默许体例。可转动性能够在游标中任何中央随机提取恣意行。游标的手艺在SQL2000下变得功效很壮大,他的目标是撑持轮回。有四个并发选项READ_ONLY:不同意经由过程游标定位更新(Update),且在构成了局集的行中没有锁。OPTIMISTICWITHvalueS:悲观并发把持是事件把持实际的一个尺度部分。悲观并发把持用于如许的情况,即在翻开游标及更新行的距离中,只要很小的时机让第二个用户更新某一行。当某个游标以此选项翻开时,没有锁把持个中的行,这将有助于最年夜化其处置才能。假如用户试图修正某一行,则此行确当前值会与最初一次提取此行时猎取的值举行对照。假如任何值产生改动,则服务器就会晓得其别人已更新了此行,并会前往一个毛病。假如值是一样的,服务器就实行修正。选择这个并发选项OPTIMISTICWITHROWVERSIONING:此悲观并发把持选项基于行版本把持。利用行版本把持,个中的表必需具有某种版本标识符,服务器可用它来断定该行在读进游标后是不是有所变动。在SQLServer中,这本性能由timestamp数据范例供应,它是一个二进制数字,暗示数据库中变动的绝对按次。每一个数据库都有一个全局以后工夫戳值:@@DBTS。每次以任何体例变动带有timestamp列的行时,SQLServer先在工夫戳列中存储以后的@@DBTS值,然后增添@@DBTS的值。假如某个表具有timestamp列,则工夫戳会被记到行级。服务器就能够对照某行确当前工夫戳值和前次提取时所存储的工夫戳值,从而断定该行是不是已更新。服务器不用对照一切列的值,只需对照timestamp列便可。假如使用程序对没有timestamp列的表请求基于行版本把持的悲观并发,则游标默许为基于数值的悲观并发把持。SCROLLLOCKS这个选项完成失望并发把持。在失望并发把持中,在把数据库的行读进游标了局集时,使用程序将试图锁定命据库行。在利用服务器游标时,将行读进游标时会在其上安排一个更新锁。假如在事件内翻开游标,则该事件更新锁将一向坚持到事件被提交或回滚;当提取下一行时,将撤除游标锁。假如在事件外翻开游标,则提取下一行时,锁就被抛弃。因而,每当用户必要完整的失望并发把持时,游标都应在事件内翻开。更新锁将制止任何别的义务猎取更新锁或排它锁,从而制止别的义务更新该行。但是,更新锁其实不制止共享锁,以是它不会制止别的义务读取行,除非第二个义务也在请求带更新锁的读取。转动锁依据在游标界说的Select语句中指定的锁提醒,这些游标并发选项能够天生转动锁。转动锁在提取时在每行上猎取,并坚持到下次提取大概游标封闭,以先产生者为准。下次提取时,服务器为新提取中的行猎取转动锁,并开释前次提取中行的转动锁。转动锁自力于事件锁,并能够坚持到一个提交或回滚操纵以后。假如提交时封闭游标的选项为关,则COMMIT语句其实不封闭任何翻开的游标,并且转动锁被保存到提交以后,以保护对所提取数据的断绝。所猎取转动锁的范例取决于游标并发选项和游标Select语句中的锁提醒。锁提醒只读悲观数值悲观行版本把持锁定无提醒未锁定未锁定未锁定更新NOLOCK未锁定未锁定未锁定未锁定HOLDLOCK共享共享共享更新UPDLOCK毛病更新更新更新TABLOCKX毛病未锁定未锁定更新别的未锁定未锁定未锁定更新*指定NOLOCK提醒将使指定了该提醒的表在游标内是只读的。
  16、用Profiler来跟踪查询,失掉查询所需的工夫,找出SQL的成绩地点;用索引优化器优化索引
  17、注重UNion和UNionall的区分。UNIONall好
  18、注重利用DISTINCT,在没有需要时不要用,它同UNION一样会使查询变慢。反复的纪录在查询里是没有成绩的
  19、查询时不要前往不必要的行、列
  20、用sp_configurequerygovernorcostlimit大概SETQUERY_GOVERNOR_COST_LIMIT来限定查询损耗的资本。当评价查询损耗的资本超越限定时,服务器主动作废查询,在查询之前就抹杀失落。SETLOCKTIME设置锁的工夫
  21、用selecttop100/10Percent来限定用户前往的行数大概SETROWCOUNT来限定操纵的行
  22、在SQL2000之前,一样平常不要用以下的字句:"ISNULL","","!=","!>","!<","NOT","NOTEXISTS","NOTIN","NOTLIKE",and"LIKE%500",由于他们不走索引满是表扫描。也不要在Where字句中的列名加函数,如Convert,substring等,假如必需用函数的时分,创立盘算列再创立索引来替换.还能够变通写法:WhereSUBSTRING(firstname,1,1)=m改成Wherefirstnamelikem%(索引扫描),必定要将函数和列名分隔。而且索引不克不及建得太多和太年夜。NOTIN会屡次扫描表,利用EXISTS、NOTEXISTS,IN,LEFTOUTERJOIN来替换,出格是左毗连,而Exists比IN更快,最慢的是NOT操纵.假如列的值含有空,之前它的索引不起感化,如今2000的优化器可以处置了。不异的是ISNULL,"NOT","NOTEXISTS","NOTIN"能优化她,而""等仍是不克不及优化,用不到索引。
  23、利用QueryAnalyzer,检察SQL语句的查询企图和评价剖析是不是是优化的SQL。一样平常的20%的代码占有了80%的资本,我们优化的重点是这些慢的中央。
  24、假如利用了IN大概OR等时发明查询没有走索引,利用显现声名指定索引:Select*FROMPersonMember(INDEX=IX_Title)WhereprocessidIN(男,女)
  25、将必要查询的了局事后盘算好放在表中,查询的时分再Select。这在SQL7.0之前是最主要的手腕。比方病院的住院费盘算。
  26、MIN()和MAX()能利用到符合的索引。
  27、数据库有一个准绳是代码离数据越近越好,以是优先选择Default,顺次为Rules,Triggers,Constraint(束缚如外健主健CheckUNIQUE……,数据范例的最年夜长度等等都是束缚),Procedure.如许不但保护事情小,编写程序质量高,而且实行的速率快。
  28、假如要拔出年夜的二进制值到Image列,利用存储历程,万万不要用内嵌Insert来拔出(不知JAVA是不是)。由于如许使用程序起首将二进制值转换成字符串(尺寸是它的两倍),服务器遭到字符后又将他转换成二进制值.存储历程就没有这些举措:办法:Createprocedurep_insertasinsertintotable(Fimage)values(@image),在前台挪用这个存储历程传进二进制参数,如许处置速率分明改良。
  29、Between在某些时分比IN速率更快,Between可以更快地依据索引找到局限。用查询优化器可见赴任别。select*fromchineseresumewheretitlein(男,女)Select*fromchineseresumewherebetween男and女是一样的。因为in会在对照屡次,以是偶然会慢些。
  30、在需要是对全局大概部分一时表创立索引,偶然可以进步速率,但不是必定会如许,由于索引也泯灭大批的资本。他的创立同是实践表一样。
 31、不要建没有感化的事物比方发生报表时,华侈资本。只要在需要利用事物时利用它。

  32、用OR的字句能够分化成多个查询,而且经由过程UNION毗连多个查询。他们的速率只同是不是利用索引有关,假如查询必要用到团结索引,用UNIONall实行的效力更高.多个OR的字句没有效到索引,改写成UNION的情势再试图与索引婚配。一个关头的成绩是不是用到索引。
  33、只管罕用视图,它的效力低。对视图操纵比间接对表操纵慢,能够用storedprocedure来取代她。出格的是不要用视图嵌套,嵌套视图增添了寻觅原始材料的难度。我们看视图的实质:它是寄存在服务器上的被优化好了的已发生了查询计划的SQL。对单个表检索数据时,不要利用指向多个表的视图,间接从表检索大概仅仅包括这个表的视图上读,不然增添了不用要的开支,查询遭到搅扰.为了加速视图的查询,MsSQL增添了视图索引的功效。
  34、没有需要时不要用DISTINCT和ORDERBY,这些举措能够改在客户端实行。它们增添了分外的开支。这同UNION和UNIONALL一样的事理。
    selecttop20ad.companyname,comid,position,ad.referenceid,worklocation,convert(varchar(10),ad.postDate,120)aspostDate1,workyear,degreedescriptionFROMjobcn_query.dbo.COMPANYAD_queryadwherereferenceIDin(JCNAD00329667,JCNAD132168,JCNAD00337748,JCNAD00338345,
  JCNAD00333138,JCNAD00303570,JCNAD00303569,
  JCNAD00303568,JCNAD00306698,JCNAD00231935,JCNAD00231933,
  JCNAD00254567,JCNAD00254585,JCNAD00254608,
  JCNAD00254607,JCNAD00258524,JCNAD00332133,JCNAD00268618,
  JCNAD00279196,JCNAD00268613)orderbypostdatedesc


  35、在IN前面值的列表中,将呈现最频仍的值放在最后面,呈现得起码的放在最初面,削减判别的次数。
  36、当用SelectINTO时,它会锁住体系表(sysobjects,sysindexes等等),堵塞其他的毗连的存取。创立一时表时用显现声名语句,而不是selectINTO.droptablet_lxhbegintranselect*intot_lxhfromchineseresumewherename=XYZ--commit在另外一个毗连中Select*fromsysobjects能够看到SelectINTO会锁住体系表,Createtable也会锁体系表(不论是一时表仍是体系表)。以是万万不要在事物内利用它!!!如许的话假如是常常要用的一时表请利用实表,大概一时表变量。
  37、一样平常在GROUPBY个HAVING字句之前就可以剔除过剩的行,以是只管不要用它们来做剔除行的事情。他们的实行按次应当以下最优:select的Where字句选择一切符合的行,GroupBy用来分组个统计行,Having字句用来剔除过剩的分组。如许GroupBy个Having的开支小,查询快.关于年夜的数据行举行分组和Having非常损耗资本。假如GroupBY的目标不包含盘算,只是分组,那末用Distinct更快
  38、一次更新多笔记录比分屡次更新每次一条快,就是说批处置好
  39、罕用一时表,只管用了局集和Table类性的变量来取代它,Table范例的变量比一时表好
  40、在SQL2000下,盘算字段是能够索引的,必要满意的前提以下:
  a、盘算字段的表达是断定的
  b、不克不及用在TEXT,Ntext,Image数据范例
  c、必需配制以下选项ANSI_NULLS=ON,ANSI_PADDINGS=ON,…….
  41、只管将数据的处置事情放在服务器上,削减收集的开支,如利用存储历程。存储历程是编译好、优化过、而且被构造到一个实行计划里、且存储在数据库中的SQL语句,是把持流言语的汇合,速率固然快。重复实行的静态SQL,可使用一时存储历程,该历程(一时表)被放在Tempdb中。之前因为SQLSERVER对庞大的数学盘算不撑持,以是不能不将这个事情放在其他的层上而增添收集的开支。SQL2000撑持UDFs,如今撑持庞大的数学盘算,函数的前往值不要太年夜,如许的开支很年夜。用户自界说函数象光标一样实行的损耗大批的资本,假如前往年夜的了局接纳存储历程
  42、不要在一句话里再三的利用不异的函数,华侈资本,将了局放在变量里再挪用更快
  43、SelectCOUNT(*)的效力教低,只管变通他的写法,而EXISTS快.同时请注重区分:selectcount(Fieldofnull)fromTable和selectcount(FieldofNOTnull)fromTable的前往值是分歧的!!!
  44、当服务器的内存够多时,配制线程数目=最年夜毗连数+5,如许能发扬最年夜的效力;不然利用配制线程数目<最年夜毗连数启用SQLSERVER的线程池来办理,假如仍是数目=最年夜毗连数+5,严峻的伤害服务器的功能。
  45、依照必定的序次来会见你的表。假如你先锁住表A,再锁住表B,那末在一切的存储过程当中都要依照这个按次来锁定它们。假如你(不经意的)某个存储过程当中先锁定表B,再锁定表A,这大概就会招致一个逝世锁。假如锁定按次没有被事后具体的计划好,逝世锁很难被发明
  46、经由过程SQLServerPerformanceMonitor监督响应硬件的负载Memory:PageFaults/sec计数器假如该值偶然走高,标明事先有线程合作内存。假如延续很高,则内存多是瓶颈。
  Process:
  1、%DPCTime指在典范距离时代处置器用在缓延程序挪用(DPC)吸收和供应服务的百分比。(DPC正在运转的为比尺度距离优先权低的距离)。因为DPC是以特权形式实行的,DPC工夫的百分比为特权工夫百分比的一部分。这些工夫独自盘算而且不属于距离盘算总数的一部分。这个总数显现了作为实例工夫百分比的均匀忙时。
  2、%ProcessorTime计数器 假如该参数值延续凌驾95%,标明瓶颈是CPU。能够思索增添一个处置器或换一个更快的处置器。
  3、%PrivilegedTime指非闲置处置器工夫用于特权形式的百分比。(特权形式是为操纵体系组件和利用硬件驱动程序而计划的一种处置形式。它同意间接会见硬件和一切内存。另外一种形式为用户形式,它是一种为使用程序、情况分体系和整数分体系计划的一种无限处置形式。操纵体系将使用程序线程转换成特权形式以会见操纵体系服务)。特权工夫的%包含为中断和DPC供应服务的工夫。特权工夫比率高多是因为失利设备发生的年夜数目的距离而引发的。这个计数器将均匀忙时作为样本工夫的一部分显现。
  4、%UserTime暗示泯灭CPU的数据库操纵,如排序,实行aggregatefunctions等。假如该值很高,可思索增添索引,只管利用复杂的表连接,程度支解年夜表格等办法来下降该值。PhysicalDisk:CurretnDiskQueueLength计数器该值应不凌驾磁盘数的1.5~2倍。要进步功能,可增添磁盘。SQLServer:CacheHitRatio计数器该值越高越好。假如延续低于80%,招考虑增添内存。注重该参数值是从SQLServer启动后,就一向累加记数,以是运转经由一段工夫后,该值将不克不及反应体系以后值。
 47、剖析selectemp_nameformemployeewheresalary>3000在此语句中若salary是Float范例的,则优化器对其举行优化为Convert(float,3000),由于3000是个整数,我们应在编程时利用3000.0而不要等运转时让DBMS举行转化。一样字符和整型数据的转换。
  48、查询的联系关系同写的按次
    selecta.personMemberID,*fromchineseresumea,personmemberbwherepersonMemberID=b.referenceidanda.personMemberID=JCNPRH39681(A=B,B=号码)
  
  selecta.personMemberID,*fromchineseresumea,personmemberbwherea.personMemberID=b.referenceidanda.personMemberID=JCNPRH39681andb.referenceid=JCNPRH39681(A=B,B=号码,A=号码)
  
  selecta.personMemberID,*fromchineseresumea,personmemberbwhereb.referenceid=JCNPRH39681anda.personMemberID=JCNPRH39681(B=号码,A=号码)

  49、
  (1)IF没有输出卖力人代码THENcode1=0code2=9999ELSEcode1=code2=卖力人代码ENDIF实行SQL语句为:Select卖力人名FROMP2000Where卖力人代码>=:code1AND卖力人代码<=:code2
  (2)IF没有输出卖力人代码THEN Select卖力人名FROMP2000ELSEcode=卖力人代码Select卖力人代码FROMP2000Where卖力人代码=:codeENDIF第一种办法只用了一条SQL语句,第二种办法用了两条SQL语句。在没有输出卖力人代码时,第二种办法明显比第一种办法实行效力高,由于它没无限制前提;在输出了卖力人代码时,第二种办法仍旧比第一种办法效力高,不但是少了一个限定前提,还因相称运算是最快的查询运算。我们写程序不要怕贫苦
  50、关于JOBCN如今查询分页的新办法(以下),用功能优化器剖析功能的瓶颈,假如在I/O大概收集的速率上,以下的办法优化实在无效,假如在CPU大概内存上,用如今的办法更好。请辨别以下的办法,申明索引越小越好。
    begin
  
  DECLARE@local_variabletable(FIDintidentity(1,1),ReferenceIDvarchar(20))
  
  insertinto@local_variable(ReferenceID)
  
  selecttop100000ReferenceIDfromchineseresumeorderbyReferenceID
  
  select*from@local_variablewhereFid>40andfid<=60
  
  end和
  
  begin
  
  DECLARE@local_variabletable(FIDintidentity(1,1),ReferenceIDvarchar(20))
  
  insertinto@local_variable(ReferenceID)
  
  selecttop100000ReferenceIDfromchineseresumeorderbyupdatedate
  
  select*from@local_variablewhereFid>40andfid<=60
  
  end的分歧
  
  begin
  
  createtable#temp(FIDintidentity(1,1),ReferenceIDvarchar(20))
  
  insertinto#temp(ReferenceID)
  
  selecttop100000ReferenceIDfromchineseresumeorderbyupdatedate
  
  select*from#tempwhereFid>40andfid<=60droptable#temp
  
  end
 另附:存储历程编写履历和优化措施From:网页教授教养网
  1、合适读者工具:数据库开辟程序员,数据库的数据量良多,触及到对SP(存储历程)的优化的项目开辟职员,对数据库有浓郁乐趣的人。
  2、先容:在数据库的开辟过程当中,常常会碰到庞大的营业逻辑和对数据库的操纵,这个时分就会用SP来封装数据库操纵。假如项目标SP较多,誊写又没有必定的标准,将会影响今后的体系保护坚苦和年夜SP逻辑的难以了解,别的假如数据库的数据量年夜大概项目对SP的功能请求很,就会碰到优化的成绩,不然速率有大概很慢,经由亲自履历,一个经由优化过的SP要比一本性能差的SP的效力乃至高几百倍。
  3、内容:
  1、开辟职员假如用到其他库的Table或View,务必在以后库中创建View来完成跨库操纵,最好不要间接利用“databse.dbo.table_name”,由于sp_depends不克不及显现出该SP所利用的跨库table或view,不便利校验。
  2、开辟职员在提交SP前,必需已利用setshowplanon剖析过查询企图,做过本身的查询优化反省。
  3、高程序运转效力,优化使用程序,在SP编写过程当中应当注重以下几点:
  a)SQL的利用标准:
  i. 只管制止年夜事件操纵,慎用holdlock子句,进步体系并发才能。
  ii. 只管制止重复会见统一张或几张表,特别是数据量较年夜的表,能够思索先依据前提提取数据光临时表中,然后再做毗连。
  iii. 只管制止利用游标,由于游标的效力较差,假如游标操纵的数据凌驾1万行,那末就应当改写;假如利用了游标,就要只管制止在游标轮回中再举行表毗连的操纵。
  iv. 注重where字句写法,必需思索语句按次,应当依据索引按次、局限巨细来断定前提子句的前后按次,尽量的让字段按次与索引按次相分歧,局限从年夜到小。
  v. 不要在where子句中的“=”右边举行函数、算术运算或其他表达式运算,不然体系将大概没法准确利用索引。
  vi. 只管利用exists取代selectcount(1)来判别是不是存在纪录,count函数只要在统计表中一切行数时利用,并且count(1)比count(*)更无效率。
  vii. 只管利用“>=”,不要利用“>”。
  viii. 注重一些or子句和union子句之间的交换
  ix. 注重表之间毗连的数据范例,制止分歧范例数据之间的毗连。
  x. 注重存储过程当中参数和数据范例的干系。
  xi. 注重insert、update操纵的数据量,避免与其他使用抵触。假如数据量凌驾200个数据页面(400k),那末体系将会举行锁晋级,页级锁会晋级成表级锁。
  b)索引的利用标准:
  i. 索引的创立要与使用分离思索,倡议年夜的OLTP表不要凌驾6个索引。
  ii. 尽量的利用索引字段作为查询前提,特别是聚簇索引,需要时能够经由过程indexindex_name来强迫指定索引
  iii. 制止对年夜表查询时举行tablescan,需要时思索新建索引。
  iv. 在利用索引字段作为前提时,假如该索引是团结索引,那末必需利用到该索引中的第一个字段作为前提时才干包管体系利用该索引,不然该索引将不会被利用。
  v. 要注重索引的保护,周期性重修索引,从头编译存储历程。
  c)tempdb的利用标准:
  i. 只管制止利用distinct、orderby、groupby、having、join、cumpute,由于这些语句会减轻tempdb的包袱。
  ii. 制止频仍创立和删除一时表,削减体系表资本的损耗。
  iii. 在新建一时表时,假如一次性拔出数据量很年夜,那末可使用selectinto取代createtable,制止log,进步速率;假如数据量不年夜,为了和缓体系表的资本,倡议先createtable,然后insert。
  iv. 假如一时表的数据量较年夜,必要创建索引,那末应当将创立一时表和创建索引的历程放在独自一个子存储过程当中,如许才干包管体系可以很好的利用到该一时表的索引。
  v. 假如利用到了一时表,在存储历程的最初务势必一切的一时表显式删除,先truncatetable,然后droptable,如许能够制止体系表的较长工夫锁定。
  vi. 慎用年夜的一时表与其他年夜表的毗连查询和修正,减低体系表包袱,由于这类操纵会在一条语句中屡次利用tempdb的体系表。
  d)公道的算法利用:
  依据下面已提到的SQL优化手艺和ASETuning手册中的SQL优化内容,分离实践使用,接纳多种算法举行对照,以取得损耗资本起码、效力最高的办法。详细可用ASE调优命令:setstatisticsioon,setstatisticstimeon,setshowplanon等。


用一个库#bak_database存放这些历史数据。
变相怪杰 该用户已被删除
沙发
发表于 2015-1-21 07:44:12 | 只看该作者
从底层原理到表层引用,书籍多的很。个人认为没有什么那本书好?这样的说法。主要看和个人的学习方法是否适合。
活着的死人 该用户已被删除
板凳
发表于 2015-1-30 11:19:59 | 只看该作者
这就引发了对varchar和char效率讨论的老问题。到底如何分配varchar的数据,是否会出现大规模的碎片?
只想知道 该用户已被删除
地板
发表于 2015-2-6 10:55:48 | 只看该作者
大家注意一点。如下面的例子:
爱飞 该用户已被删除
5#
发表于 2015-2-16 00:15:17 | 只看该作者
对一张百万级别的表建游标,同时又没有什么过滤条件,取得游标效率是如果直接SQL查询百万条数据;如果再对每条记录做处理,耗时将更长。
因胸联盟 该用户已被删除
6#
发表于 2015-3-4 19:12:54 | 只看该作者
再开发调试阶段和OLAP环境中,外键是可以建立的。新版本中加入了SETNULL和SETDEFAULT属性,能够提供能好的级联设置。
兰色精灵 该用户已被删除
7#
发表于 2015-3-11 20:45:06 | 只看该作者
这是一个不错的新特性。虽然索引的附加字段没有索引键值效率高,但是相对映射到数据表中效率还是提高了很多。我做过试验,在我的实验环境中会比映射到表中提高30%左右的效率。
谁可相欹 该用户已被删除
8#
发表于 2015-3-19 12:36:08 | 只看该作者
光写几个SQL实在叫无知。
蒙在股里 该用户已被删除
9#
发表于 2015-3-28 02:51:08 | 只看该作者
一直以来个人感觉SQLServer的优化器要比Oracle的聪明。SQL2005的更是比2k聪明了不少。(有次作试验发现有的语句在200万级时还比50万级的相同语句要快show_text的一些提示没有找到解释。一直在奇怪。)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|仓酷云 鄂ICP备14007578号-2

GMT+8, 2024-12-22 19:07

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表