如何查询mysql中执行效率低的sql语句

整理文档很辛苦,赏杯茶钱您下走!

免费阅读已结束,点击下载阅读编辑剩下 ...

阅读已结束,您可以下载文档离线阅读编辑

资源描述

配置my.cnf/my.ini,增加--log-slow-queries配置,记录所有的slowquery,然后挨个优化本文来源于WEB开发网原文链接:@a=DRClass1,@b=DRClass2,@c=DRClass3,@d=DRClass4,@e=DRClass5fromTeacherWhereTeacherID=@TeacherIDcreatetableclassname(classnamechar(50))insertintoclassname(classname)values(@a)if(@bisnotnull)begininsertintoclassname(classname)values(@b)if(@cisnotnull)begininsertintoclassname(classname)values(@c)if(@disnotnull)begininsertintoclassname(classname)values(@d)if(@eisnotnull)begininsertintoclassname(classname)values(@e)endendendendselect*fromclassname以上这些SQL语句能不能转成一个存储过程?我自己试了下ALTERPROCEDUREPr_GetClass@TeacherIDint,@achar(50),@bchar(50),@cchar(50),@dchar(50),@echar(50)asselect@a=DRClass1,@b=DRClass2,@c=DRClass3,@d=DRClass4,@e=DRClass5fromTeacherWhereTeacherID=@TeacherIDDROPTABLEclassnamecreatetableclassname(classnamechar(50))insertintoclassname(classname)values(@a)if(@bisnotnull)begininsertintoclassname(classname)values(@b)if(@cisnotnull)begininsertintoclassname(classname)values(@c)if(@disnotnull)begininsertintoclassname(classname)values(@d)if(@eisnotnull)begininsertintoclassname(classname)values(@e)endendendendselect*fromclassname但是这样的话,这个存储过程就有6个变量,实际上应该只提供一个变量就可以了主要的问题就是自己没搞清楚@a,@b,@C,@d等是临时变量,是放在as后面重新做一些申明的,而不是放在开头整个存储过程的变量定义。(标准化越来越近了):namespaceprefix=ons=urn:schemas-microsoft-com:office:office/实战SQL语句收集(不断更新中--)前言:这里将我编程实践中遇到的有价值的sql语句一路记下来,一方面方便自己查用,一方面也夯实下即将遗忘的回忆。整个过程中我会不断更新,直到不能再加为止,同时,这里只记录最实用的咚咚,不效仿学院派的那一套。一、常用SQL语句荟萃1,查询:1.1,简单查询:select*fromtablewhere1.2,连接查询:什么是连接查询?顾名释义,就是查询时涉及多个表的查询。是以说到连接,废话一下,要知道连接还是关系数据库的主要特点呢。连接查询分为三种:外连接(OUTERJOIN),内连接(INNERJOIN),交叉连接(CROSSJOIN)。(标准化越来越近了):namespaceprefix=st1ns=urn:schemas-microsoft-com:office:smarttags/1.2.1,内连接(INNERJOIN)使用比较运算符进行表间某(些)列数据的比较操作,并列出这些表中与连接条件相匹配的数据行。根据所使用的比较方式不同,内连接又分为等值连接、自然连接和不等连接三种。1.2.2,外连接分为左外连接(LEFTOUTERJOIN或LEFTJOIN)、右外连接(RIGHTOUTERJOIN或RIGHTJOIN)和全外连接(FULLOUTERJOIN或FULLJOIN)三种。与内连接不同的是,外连接不只列出与连接条件相匹配的行,而是列出左表(左外连接时)、右表(右外连接时)或两个表(全外连接时)中所有符合搜索条件的数据行。1.2.3,交叉连接(CROSSJOIN)没有WHERE子句,它返回连接表中所有数据行的笛卡尔积,其结果集合中的数据行数等于第一个表中符合查询条件的数据行数乘以第二个表中符合查询条件的数据行数。连接操作中的ON(join_condition)子句指出连接条件,它由被连接表中的列和比较运算符、逻辑运算符等构成。1.2.4,无论哪种连接都不能对text、ntext和image数据类型列进行直接连接,但可以对这三种列进行间接连接。例如:SELECTp1.pub_id,p2.pub_id,p1.pr_infoFROMpub_infoASp1INNERJOINpub_infoASp2ONDATALENGTH(p1.pr_info)=DATALENGTH(p2.pr_info)1.2.5,使用WHERE子句设置查询条件WHERE子句设置查询条件,过滤掉不需要的数据行。例如下面语句查询年龄大于20的数据:SELECT*FROMusertableWHEREage20WHERE子句可包括各种条件运算符:比较运算符(大小比较):、=、=、、=、、!、!范围运算符(表达式值是否在指定的范围):BETWEEN…AND…NOTBETWEEN…AND…列表运算符(判断表达式是否为列表中的指定项):IN(项1,项2……)NOTIN(项1,项2……)模式匹配符(判断值是否与指定的字符通配格式相符):LIKE、NOTLIKE空值判断符(判断表达式是否为空):ISNULL、NOTISNULL逻辑运算符(用于多条件的逻辑连接):NOT、AND、OR1、范围运算符例:ageBETWEEN10AND30相当于age=10ANDage=302、列表运算符例:countryIN('Germany','China')3、模式匹配符例:常用于模糊查找,它判断列值是否与指定的字符串格式相匹配。可用于char、varchar、text、ntext、datetime和smalldatetime等类型查询。可使用以下通配字符:百分号%:可匹配任意类型和长度的字符,如果是中文,请使用两个百分号即%%。下划线_:匹配单个任意字符,它常用来限制表达式的字符长度。方括号[]:指定一个字符、字符串或范围,要求所匹配对象为它们中的任一个。[^]:其取值也[]相同,但它要求所匹配对象为指定字符以外的任一个字符。例如:限制以Publishing结尾,使用LIKE'%Publishing'限制以A开头:LIKE'[A]%'限制以A开头外:LIKE'[^A]%'空值判断符例:WHEREageISNULL2,更新:updatetable3,插入:3.1,一般插入:INSERTINTOpublishers(pub_id,pub_name,city,state)VALUES('9001','AcmePublishing','NewYork','NY')3.2,插入多行使用INSERT语句可以向表添加多行数据。这些多行数据是从已经存有这些数据的另一个表中选取的。本例中,向pubhold表中添加有关在加利福尼亚和德克萨斯州的出版商的数据。这些数据可从publishers表中获得。INSERTpubhpoldSELECT*FROMpublishersWHEREstate='CA'ORstate='TX'4,删除:4.1,Delete语句联合删除:DELETEFROMuu_SuiteToMinClassroomSectWHEREmin_classroom_sect_idIN(SELECTmin_classroom_sect_idFROMuu_MinClassroomSectWHEREmin_classroom_id='112')二、视图使用细则1,一个典型的视图CREATEVIEWView_uuGroupTaxisASSELECTuu_GroupInfo.group_id,uu_GroupInfo.group_name,uu_GroupType.main_type,uu_GroupType.group_type_name,uu_GroupInfo.group_icon_url,ISNULL((SELECTCOUNT(*)FROMuu_GroupUserWHEREuu_GroupInfo.group_id=uu_GroupUser.group_id),0)*50+ISNULL(uu_GroupInfo.fundCount,0)+ISNULL((SELECTCOUNT(*)FROMDv_TopicWHEREDv_Topic.BoardID=uu_GroupInfo.subforum_id),0)*5+ISNULL((SELECTCOUNT(*)FROMuu_GroupPhotosWHEREuu_GroupPhotos.group_id=uu_GroupInfo.group_id),0)*10+ISNULL(uu_GroupInfo.topic_account,0)*2+ISNULL(uu_GroupInfo.hit_account,0)ASgroup_ActiveDegree,ISNULL((SELECTCOUNT(*)FROMuu_GroupUserWHEREuu_GroupInfo.group_id=uu_GroupUser.group_id),0)ASgroup_memberNum,ISNULL(uu_GroupInfo.fundCount,0)ASfundCount,(SELECTCOUNT(*)FROMDv_TopicWHEREDv_Topic.BoardID=uu_GroupInfo.subforum_id)ASgroup_articleNum,(SELECTCOUNT(*)FROMuu_GroupPhotosWHEREuu_GroupPhotos.group_id=uu_GroupInfo.group_id)ASgroup_PhotoNum,uu_GroupInfo.topic_account,uu_GroupInfo.hit_account,(SELECTuser_nameFROMuu_RegisterUserWHEREuu_RegisterUser.user_id=uu_GroupInfo.creator_id)ASgroup_CreatorName,uu_GroupInfo.create_timeFROMuu_GroupInfoINNERJOINuu_GroupTypeONuu_GroupInfo.group_type_id=uu_GroupType.group_type_id三,存储过程的创建和调用1,存储过程的调用ExecuteprocedureName@param=’value’2,一个典型的带参数存储过程CREATEPROCEDUREP_delMiniclassProc@miniClassroom_idintASdeclare@billtagvarchar(4)setnocountonIF@miniClassroom_idisnullbeginreturn(-1)endelseBEGINTRANSACTION--删除套餐信息DELETEFROMuu_SuiteToMinClassro

1 / 18
下载文档,编辑使用

©2015-2020 m.777doc.com 三七文档.

备案号:鲁ICP备2024069028号-1 客服联系 QQ:2149211541

×
保存成功