由于公司基本都是用存储过程因此原本写的干货基本都是存储过程的。sql
SELECT TOP 1 Code,Invitation,Num,Typ FROM SignLog WITH(NOLOCK) WHERE UserId=@userId AND TaskId=2 AND AddTime>=@stime AND AddTime<@etime
用以上语句来讲一下例子:spa
查询 必定要指定字段就算你要查所有字段也不要用*号来代替 ,以及 能用TOP尽可能TOPcode
避免不必的锁 必须加 WITH(NOLOCK) 避免产生没有必要的锁出来。blog
由于字段多,数据多一个索引没有走。索引
加了字段后就会快不少比你查所有的快不少,精准的查询。it
------------------------------------------------------------------------------------------------------------io
UserId=@userId AND TaskId=2 AND AddTime>=@stime AND AddTime<@etime 若是UserId和AddTime是索引,TaskId不是,那像上面这样只会走一个索引。
UserId=@userId AND AddTime>=@stime AND AddTime<@etime AND TaskId=2 若是改为上面这样就会走两个索引。
UPDATE SignLog SET NUM+=1 WHERE UserId=@userId AND AddTime>=@stime AND AddTime<@etime AND TaskId=2
像上面这样的更改语句这样写是没有什么的,若是是在存储过程写的话像下面同样写会比你上面写法快。
DECLARE @ID INT=0 SELECT TOP 1 @ID=ID FROM SignLog WITH(NOLOCK) WHERE UserId=@userId AND AddTime>=@stime AND AddTime<@etime AND TaskId=2 UPDATE SignLog SET NUM+=1 WHERE ID=@ID
像这样写正常会快点,并且也不会产生没有必要的锁出来,并且该走的索引都走了。class
能走索引就走索引,索引确定比你正常的快丶丶。im
-------------------------------------------------------------------------------------------------------------d3
UPDATE dbo.Activity_RoomActivity SET ActivityState=2 WHERE ActivityState=0 AND StartTime<DATEADD(hh,-1,GETDATE())
这样更新一个索引没有走上,并且还一条一条改。
能够改为如下差很少的。
SELECT Id INTO #temp FROM dbo.Activity_RoomActivity WITH(NOLOCK) WHERE ActivityState=0 AND StartTime<DATEADD(hh,-1,GETDATE()) UPDATE t1 SET t1.ActivityState=2 FROM dbo.Activity_RoomActivity t1,#temp t2 WHERE t1.Id=t2.Id
这样修改的时候就会走索引去修改。
SELECT DATEDIFF(S,'1970-01-01 8:00:00', @addTime)