≡
  • 网络编程
  • 数据库
  • CMS技巧
  • 软件编程
  • PHP笔记
  • JavaScript
  • MySQL
位置:首页 > 数据库 > SQL Server

浅谈数据库优化方案

人气:330 时间:2020-04-29

这篇文章主要为大家详细介绍了浅谈数据库优化方案,具有一定的参考价值,可以用来参考一下。

感兴趣的小伙伴,下面一起跟随四海网的小编两巴掌来看看吧!

本文为大家分享了数据库优化方案,供大家参考,具体内容如下

 

1. 利用表分区


分区将数据在物理上分隔开,不同分区的数据可以制定保存在处于不同磁盘上的数据文件里。这样,当对这个表进行查询时,只需要在表分区中进行扫描,而不必进行全表扫描,明显缩短了查询时间,另外处于不同磁盘的分区也将对这个表的数据传输分散在不同的磁盘I/O,一个精心设置的分区可以将数据传输对磁盘I/O竞争均匀地分散开。对数据量大的时时表可采取此方法。可按月自动建表分区。

 

 

2. 别名的使用

 
别名是大型数据库的应用技巧,就是表名、列名在查询中以一个字母为别名,查询速度要比建连接表快1.5倍。 

 

 

3. 索引Index的优化设计

索引可以大大加快数据库的查询速度。但是并不是所有的表都需要建立索引,只针对大数据量的表建立索引就好。
缺点:
1.创建索引和维护索引要耗费时间,这种时间随着数据量的增加而增加。
2.索引需要占物理空间,除了数据表占数据空间之外,每一个索引还要占一定的物理空间,如果要建立聚簇索引,那么需要的空间就会更大。
3.当对表中的数据进行增加、删除和修改的时候,索引也要动态的维护,这样就降低了数据的维护速度。
索引需要维护:为了维护系统性能,索引在创建之后,由于频繁地对数据进行增加、删除、修改等操作使得索引页发生碎块,因此,必须对索引进行维护。
4. 物化视图(索引视图) 

 

一般的视图是虚拟的,而物化视图是实实在在的数据区域,是要占据存储空间的,另外系统刷新物化视图也需要耗费一定的资源,但是它却换来了效率和灵活性。
索引视图更适合在OLAP(读取较多,更新较少)的数据库中使用,不适合在OLTP(记录即时的增、删、改、查)的数据库中使用 。 

 

物化视图的注意事项:

 
1.对于复杂而高消耗的查询,如果使用频繁,应建成物化视图。 
2.物化视图是一种典型的以空间换时间的性能优化方式。 
3.对于更新频繁的表慎用物化视图。 
4.选择合适的刷新方式。 

 

 

普通视图和物化视图的区别:

普通视图和物化视图根本就不是一个东西,普通视图是不存储任何数据的,在查询中是转换为对应定义的SQL去查询,而物化视图是将数据转换为一个表,实际存储着数据,这样查询数据,就不用关联一大堆表,如果表很大的话,会在临时表空间内做大量的操作。 
普通视图的三个特征:
 1).简化设计,方便,清晰编码。视图并不是提高性能的,它的存在只会降低性能(例如我们关联两个视图,一个视图关联6个表,另一个视图关联7个表)。 
2).安全,在授权给其他用户或者查看角度,多个表关联只允许查看,不允许修改。
3.从不同的角度看不同的维度,视图可以划分维度和权限,并使多个维度的综合,也就是你要什么就可以从不同的角度看,而表是一个实体的而已,一般维度较少。 

 

 

5. 死锁与阻塞

 
1).对于需要频繁更新的数据,尽量避免放在长事务中,以免导致连锁反应。 
2).不是迫不得已,最好不要在数据库锁机制外再加自己设计的锁。 
3).减少事务大小,及时提交事务。 
4).尽量避免跨数据库的分布式事务,因为环境的复杂性,很容易导致阻塞。
5).慎用位图索引,更新时容易导致死锁。 

 

 

6.减少IO与网络传输次数 

1).尽量用较少的数据库请求,获取到需要的数据,能一次性取出的不分多次取出。 
2).对于频繁操作数据库的批量操作,应采用存储过程,减少不必要的网络传输。

 

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持四海网。

本文来自:http://www.q1010.com/179/8587-0.html

注:关于浅谈数据库优化方案的内容就先介绍到这里,更多相关文章的可以留意四海网的其他信息。

关键词:SQL SERVER

您可能感兴趣的文章

  • SQLServer主键和唯一约束的区别
  • SQLSERVER简单创建DBLINK操作远程服务器数据库的方法
  • SqlServer存储过程实现及拼接sql的注意点
  • sqlserver 各种判断是否存在(表名、函数、存储过程等)
  • 将备份的SQLServer数据库转换为SQLite数据库操作方法
  • SQLServer导出sql文件/表架构和数据操作步骤
  • 自动化收集SQLSERVER诊断信息的工具选择及使用介绍
  • SQLSERVER数据库中的5173错误解决方法
  • SqlServer系统数据库的作用深入了解
  • SQLSERVER如何查看索引缺失及DMV使用介绍
上一篇:使用SQL批量替换语句修改、增加、删除字段内容
下一篇:SQL Server表中添加新列并添加描述
热门文章
  • SQL Server SQL获取第一条记录的方法
  • SQL Server出现System.OutOfMemoryException异常的解决方法
  • SQL Server的 update from 语句的简单示例
  • SQL Server 数据库备份方法菜鸟教程
  • SQL Server 多表关联时在where语句中慎用trim()方法
  • SQL Server数据类型及长度限制详细说明
  • mybaits非配置原因,导致SqlSession was not registered for synchronization异常解析
  • SQL Server 收缩后对数据库的使用有影响吗?
  • SQL Server 格式导致的Excel导入sql出现异常的解决方法
  • SQL Server 连接服务器出现错误 7391的解决方法
  • 最新文章
    • SQL Server存储过程基本语法的简单示例
    • sql查询时增加自动编号和分页的简单示例
    • sql轻松应付百万数据的高效数据分页存储过程的简单示例
    • sql获取一条数据中所有字段的名称和值的实现方法
    • sql分割函数的简单示例
    • SQL Server异常捕获的简单示例
    • SQL SERVER回滚恢复误操作数据的实现方法
    • SQL Server函数或存储过程中抛出异常的实现方法
    • SQL Server创建数据库的完整代码
    • SQL Server创建数据库的命令用法示例

四海网收集整理一些常用的php代码,JS代码,数据库mysql等技术文章。