关于SQL SERVER高并发解决方案-阿里云开发者社区

开发者社区> 科技小毛> 正文

关于SQL SERVER高并发解决方案

简介:
+关注继续查看

现在大家都比较关心的问题就是在多用户高并发的情况下,如何开发系统,这对我们程序员来说,确实是值得研究,最近找工作面试时也经常被问到,其实我早有去关心和了解这类问题,但一直没有总结一下,导致面试时无法很完整全面的回答,所以今天我专门总结概况了一下关于SQL SERVER高并发解决方案,希望能帮助大家,若有不对之外,还请及时告之,谢谢!

SQL SERVER高并发解决方案主要是从以下几个方面:

1.SQL语句优化:

  A.尽可能的精确查询条件及查询字段,缩小查询范围(包括使用分页查询);

  B.查询条件中尽可能少用:like,(not)in,(not)is null,order by,distinct,count(*),!=,<>;

  C.不要对查询的字段进行函数运算,

    如:aa. substring('aa123',1,2)='aa',而应该是:'aa123' like 'aa%'; ---应用到了索引

      bb. 'aa'+'123'='aa123',而应该是:'aa'=left('aa123',2)

  D.判断数据存在,不要使用TOP 1,而应该是:EXITS

  E.对于复杂SQL查询,可直接使用SQL存储过程或建立视图(视图不可太复杂);

  F.尽可能的少用游标,触发器;

2.表设计优化:

  A.纵向分割表设计,将表按照某种原则(可按照字段读写频率来设计)设计成相对应的几个表,之间采用主(外)键关联查询;

  B.横向分割表设计,将表中的数据按照使用价值(比如:只用只用到近3个月的有效数据)来进行数据转移备份,以减少表的数据量;

  C.表数据物理存放分区设计,将表中的数据按照某种规则建立物理表分区来存储,以降低硬盘的IO负担;

  D.建立适当的索引(聚集索引与非聚集索引);

3.事务设置优化:

  事务隔离级别有:(隔离级别作用于事务中,而锁作用于每条SQL语句上)

隔离级别

脏读

不可重复读取

幻像

说明

 产生或等同对应的锁

未提交读(read uncommitted)

如果其他事务更新,不管是否提交,立即执行

 NOLOCK

提交读(read committed默认)

读取提交过的数据。如果其他事务更新没提交,则等待

 HOLDLOCK

可重复读(repeatable read)

查询期间,不允许其他事务update

 HOLDLOCK

可串行读(serializable)

查询期间,不允许其他事务insert或delet

 HOLDLOCK

    A.事务隔离原则:共享读,排它写,即表示:在执行查询时,若对数据一致性要求很高时,可采用可重复读(repeatable read)隔离级别,若没有严格要求,则可建议使用未提交读(read uncommitted)隔离级别;

4.服务器硬件优化:

  A.服务器内存,硬盘等核心硬件性能当然越强越好;

  B.购买多台服务器并建立集群,以实现利用多个计算机进行并行计算从而获得很高的计算速度,也可以用多个计算机做备份,从而使得任何一个机器坏了整个系统还是能正常运行;

C.在多台服务器建立DB镜像同步,并实现读写分离,即:除了指定的一台或几台服务器具有允许更新以外,其余的服务器均只作为数据镜像同步,不能更新,仅供查询;

分类: SQL
 
 
本文转自左正博客园博客,原文链接:http://www.cnblogs.com/soundcode/p/6927543.html,如需转载请自行联系原作者

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
读写分离提高 SQL Server 并发性
原文:读写分离提高 SQL Server 并发性 转自:http://www.canway.net/Lists/CanwayOriginalArticels/DispForm.aspx?ID=476 在一些大型的网站或者应用中,单台的SQL Server 服务器可能难以支撑非常大的访问压力。
763 0
数字海南加入阿里云原生合作伙伴计划并发布政务服务高可用联合解决方案
政务服务的数字化转型,会遇到诸如移动端应用需要频繁迭代、快速发版、对接数个异构业务系统不稳定的问题。亟需一个政务服务高可用解决方案,来支撑快速接入各个部门已有的业务和服务、快速迭代更新各部门新的业务服务需求,维护保持服务的稳定运行。
3390 0
【终极解决方案】为应用程序池“XXX”提供服务的进程在与 Windows Process Activation Service 通信时出现严重错误。该进程 ID 为“XXXX”。数据字段包含错误号。
原文:【终极解决方案】为应用程序池“XXX”提供服务的进程在与 Windows Process Activation Service 通信时出现严重错误。该进程 ID 为“XXXX”。数据字段包含错误号。
2250 0
sql中distinct和order by问题的解决方案
    需求:根据PID字段对数据去重,根据Sort字段排序,需要显示这个两个字段。          如图,这是原始数据,先排序:          排序后发现两个项是重复的,需要去除一个,          因为Distinct对检查Select里面的每一列,出现的每一列必须都相同才算重复数据,而排序后的数据里面相同Pid的数据的sort值不同,Distinct此时就失效了。
1172 0
SAP Server Side JavaScript解决方案
SAP Server Side JavaScript解决方案
6 0
mysql太多连接问题及解决方案
不管是JavaEE开发还是其他,只要是Linux系统下安装的mysql,通常默认最大连接为270。 如果你的客户端连接超过这个数,通常要么是配置文件修改,或者是命令行修改,配置文件修改和命令行修改的区别是,配置文件,既然是文件通常持久化到硬盘,保存最长,如果是命令行的话,仅仅只能保持在Mysql运行状态,如果一旦MySQL因为某种原因宕机或者关闭了,命令行的方式就失效了。
936 0
+关注
580
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载