转:SQLServer⾼并发解决⽅案四个优化
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.横向分割表设计,将表按照某种原则(可按照字段读写频率来设计)设计成相对应的⼏个表,之间采⽤主(外)键关联;
sql语句优化方式 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镜像同步,并实现读写分离,即:除了指定的⼀台或⼏台服务器具有允许更新以外,其余的服务器均只作为数据镜像同步,不能更新,仅供查询。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论