设为首页 收藏本站
查看: 777|回复: 0

[经验分享] sql server存储过程注意事项

[复制链接]

尚未签到

发表于 2016-11-2 00:01:19 | 显示全部楼层 |阅读模式
  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.
  

  • SELECT *  
  • INTO new_table_name   
  • 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
  

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-294236-1-1.html 上篇帖子: SQL server 中的作业信息查询 下篇帖子: SQL server中convert data函数大全
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

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