sql server存储过程注意事项

2012-11-2

批量修改sql server里的数据

利用sa帐号把数据库里的数据导出成excel表格,然后再在excel里替换相应的数据,

最后truncate table 表明将数据库里的自增字段清零,然后再打开表格数据之后清空表格数据,将excel表里的数据粘贴上去。

2012-10-31

数据库查询里尽量用exists,用在外表比较小,内表比较大的情况下, 如果内表比较小,外表比较大的话可以用in

查询武将模板表里,排除已经录取的武将。

     select * from PlayerTemplet pt 

     where  not exists 

      (select *  from player p  where p.userid = 7 and pt.PlayerTempletID = p.PlayerTempletID)


http://exmail.qq.com/

有些书适合一读再读,每次读都会有不同的收获。

http://221.215.38.136/grcx/pages/qdyth/wsbs/login.jsp

一、尽量避免反复访问同一张表或几张表,尤其是数据量较大的表,可以考虑先根据条件提取数据的保存到临时表中,然后再做连接。

二、尽量避免使用游标,因为游标的效率较差,如果游标操作的数据超过1万行,那么就应该改写,如果使用了游标,就要尽量避免在游标循环中再进行表连接的操作。

三、注意where条件的顺序 ,越能缩小范围的越要放在前面,应该根据索引顺序、范围大小来确定条件子句的前后顺序,尽可能的让字段顺序与索引顺序相一致,范围从大到小。

四、不要在where子句中的"="左边进行函数、算术运算或其他表达式运算,否则系统将可能无法正确使用索引。

五、尽量使用exists代替select count(1)来判断是否存在记录,count函数只有在统计表中所有函数是使用,而且count(1)比count(*)更有效率。

六、尽量使用">=", 不要使用">"

七、注意一些or子句和union子句之间的替换。

八、注意表之间连接的数据类型,避免不同数据之间的连接。

九、注意insert,update操作的数据量,防止与其他应用冲突,如果数据量超过200个数据页面(400k),那么系统将会进行锁升级,页级锁会升级成表级锁。

临时数据库的使用规范

1)尽量避免使用distinct、ordery by 、group by、having、join、compute,因为这些语句会加重tempdb的负担。

 2)避免频繁创建和删除临时表,减少系统表资源的消耗。

3)在新建临时表时,如果一次性插入数据量很大,那么可以使用select into 代替 create tabl,避免log,提高速度,如果数据量不大,为了缓和系统表的资源,建议先create table,然后insert.

  1. SELECT *  
  2. INTO new_table_name   
  3. FROM old_tablename 

iv. 如果临时表的数据量较大,需要建立索引,那么应该将创建临时表和建立索引的过程放在单独一个子存储过程中,这样才能保证系统能够很好的使用到该临时表的索引。

v. 如果使用到了临时表,在存储过程的最后务必将所有的临时表显式删除,先truncate table,然后drop table,这样可以避免系统表的较长时间锁定。
vi. 慎用大的临时表与其他大表的连接查询和修改,减低系统表负担,因为这种操作会在一条语句中多次使用tempdb的系统表。 

 
d)合理的算法使用:   
根据上面已提到的SQL优化技术和ASE Tuning手册中的SQL优化内容,结合实际应用,采用多种算法进行比较,以获得消耗资源最少、效率最高的方法。具体可用ASE调优命令:set statistics io on, set statistics time on , set showplan on 等。

sql 语法

1) 检索是否存在B记录,然后才检索

  select * from A exits (select * from B where conditions) 

2)检索以c1

   select c1 ,avg(c2) from A  group by c1 having count avg(c2) > 0

  查询每个部门的每种职位的雇员数

 select dept ,job,count(* ) from t group by dept, job

2012-7-16

1)不要用count(*)来判断是否有记录而是用if exits或者if not exits

 IF NOT Exists (SELECT PlayerSpecialTrainDetailID FROM PlayerSpecialTrainDetail    where  PlayerId = @PlayerId and UserID = @UserID  AND IsDue = 0)

2)存储过程用来返回是否有记录,如果有则返回0,如果没有则返回1

IF EXISTS(SELECT NULL FROM PlayerSpecialTrainDetail WITH(NOLOCK)WHERE PlayerID=@PlayerID AND IsDue=0)

BEGIN

SELECT CONVERT(BIT,0)

END

ELSE

BEGIN

SELECT CONVERT(BIT,1)

END

猜你喜欢

转载自icrwen.iteye.com/blog/1579583