**库调优

时间:2013.11.01 发布人:asdnfajwbn

**库调优

已解决问题

谷歌asdnfajwbn用户在2013.11.01提交了关于“三星堆**库调优”的提问,欢迎大家涌跃发表自己的观点。目前共有4个回答,最后更新于2025-02-18T20:05:58。

**库一般什么需要调优,怎么调优

希望大家能够帮助她。

详细问题描述及疑问:

**库一般什么需要调优,怎么调优

期待您的答案,希望你能感受到,我最真诚的谢意 !
希望以下的回答,能够帮助你。

第1个回答

用户名:藏马啸天  

简单说;

首先你得优化你的索引。其次片弱级神均距艺,少选择一些不必要的列。再次,在解释计划里面看看自己的sql执行计划,调优。

详细的,你需要看看书了。有oracel的调优书籍

第2个回答

用户名:匿名用户  

查询啊。。。建立序列什么的。。还有该使用问答什么效率高等等。。

第3个回答

用户名:阳泉一龙  

一、概述
随着**库良速在各个领域的使用不断增长,越来越多的应用提出了高性能的要求。**库性能调优是知识密集型的学科,需要综合考虑各种复杂的因素:**库缓冲区的大小、索引的创建、语句改写等等。总之,**库性能调优的目的罗会层武连在于使系统运行得更快。
优需要有广泛的知识,这使得它既简单又复杂。
说调优简单,是因顺与江府飞水为调优者不必纠缠于复杂的公式和规则。许多学术界和业界的研究者都在尝试将调优和查询处理建立在数学基础之上。
称调优复杂,是因为如果要完全理解常识所依赖的原理,还需要对应用、**库管理久阳随改春概企先无系统、操作系统以及硬件有广泛而深刻的理解。
**库调优技术可以在不同的**库系统中使用。如果需要调优考下仍剂只声**库系统,最好掌握如下知识:1)查询处理、并发控制以及**库恢复的哥知识;2)一些调优的基本原则。
这里主要兵机始来描述索引调优。
二、索引调优
索引是建立在表上的一种**组织,它能提高访问表中一条或多波包编帝际条记录的特定查询效率。因此,适当的索引调优是很重要的。
对于索引调优存在如下的几个误区:
误区1:索引创建得越多越好?
实际上:创建的索引层可能建立后从来未使用。索引派慢书后迫孩情功的创建也是需要代价的,对于删除、某些更新、插入操作,对于每个索引都要进行相应格身火厚陆天固领的删除、更新、插入操作。从而导把飞读节审酸属季球继围致删除、某些更新、插入操作的效率变低。
误区2:对于一个单表的查询,可以索引1进行过滤再使用索引2进行过滤?
实际上:假设查询语句如下select*fromt1wherec1=1andc2=2,c1列和c2列上分别建有索引ic1、ic2。先使用ic1(或ic2)进行过滤,谈木家身钟流**生的结果集是临时**,不再穿友足具有索引,所以不可使用ic2(或ic1)进行再次过滤。
索引优化的基本原则:
1、将索引和**存放到不同的文件组
没有将表**和索引**存储到不同的文件组,而不加区别地将它们存储到同一文件组。这样,不但会造成I/O竞争,也为**库的维护工作带来不变。
2、组合索引的使用
假设存在组合索引it1c1c2(c1,c2),查询语句select*fromt1wherec1=1andc2=2能够使用该索引。查询语句select*fromt1wherec1=其殖过织哥1也能够使用该索引。但是,查询语句select*fromt1wherec2=2不能够使用该索引,因为没有组合索引的引导列,即,要想使用c2列进行查找,必需出现c1等于某值。
根据where条件的不同,归纳如下:
1)c1=1andc2=2:使用索引it1c1c2进行等值查找。
2)c1=1andc2>2:使用索引it1c1c2进行范围查找,可以有两种方法。
方法1,使用通过索引键(1,2)在B树中命中一条记录,然后向后扫描找出第一条符合条件的记录,从此记录往后的每一条记录都是符合条件的。这种方法的弊端在于:如果c1=1andc2=2对应的记录数很多,会**生很多无效的扫描。
方法2,如果c2对应的int型**,可以使用索引键(1,3)在B树中命中一条记录,从此记录往后的每一条记录都是符合条件的。
本文中的例子均采用方法1。
3)c1>1andc2=2:因为索引的第一个列不是等于号的,索引即使后面出现了c2=2,也不能将c2=2应用于索引查找。这里,通过索引键(1,-∞)在B树中命中一条记录,向后扫描找出第一条符合c1>1的记录,此后的每一条记录判断是否符合c2=2,如果符合则输出,否则过滤掉。这里我们称c2=2没有参与到索引运算中去。这种情况在实际应用中经常出现。
4)c1>1:通过索引键(1,-∞)在B树中命中一条记录,以此向后扫描找出第一条符合c1>1的记录,此后的每条记录都是符合条件的。
3、唯一索引与非唯一索引的差异
假设索引int1c1(c1)是唯一索引,对于查询语句selectc1fromt1wherec1=1,达梦**库使用索引键(1)命中B树中一条记录,命中之后直接返回该记录(因为是唯一索引,所以最多只能有一条c1=1的记录)。
假设索引it1c2(c2)是非唯一索引,对于查询语句selectc2fromt2wherec2=2,达梦**库使用索引键(2)命中B树中一条记录,返回该记录,并继续向后扫描,如果该记录是满足c=2,返回该记录,继续扫描,直到遇到第一条不符合条件c2=2的记录。
于是,我们可以得知,对于不存在重复值的列,创建唯一索引优于创建非唯一索引。
4、非聚集索引的作用
每张表只可能一个聚集索引,聚集索引用来组织真实**。语句“createtableemployee(idintclusterprimarykey,namevarchar(20),addrvarchar(20))”。表employee的**用id来组织。如果要查找id=1000的员工记录,只要用索引键(1000)命中该聚集索引。但是,对于要查找name=’张三’的员工记录就不能使用该索引了,需要进行全表扫描,对于每一条记录判断是否满足name=’张三’,这样会导致查询效率非常低。
要使用聚集索引,必需提供id,我们只能提供name,于是需要引入一个**结构实现name到id的转换,这就是非聚集索引的作用。该非聚集索引的键是name,值是id。于是语句“select*fromemployeewherename=’张三’”的执行流程是:通过键(’张三’)命中非聚集索引,得到对应的id值3(假设’张三’对应的id为3),然后用键(3)命中聚集索引,得到相应的记录。
5、是不是使用非聚集索引的查询都需要进行聚集的查询?
不是的,虽然在上一点中查询转换为聚集索引的查找,有时候可以只需要使用非聚集索引。
创建表并创建相应的索引:createtablet1(c1int,c2int,c3int);createindexit1c2c3ont1(c2,c3)。查询语句为:selectc3fromt1wherec2=1。
因为索引it1c2c3(c2,c3)覆盖查询语句中的列(c2,c3)。所以,该查询语句的执行流程为:通过索引键(1,-∞)命中索引it1c2c3,对于该记录直接返回c3对应的值,继续向后扫描,如果索引记录中c1还是等于1,那么输出c3,以此类推,直到出现第一条c1不等于1的索引记录,结束查询。
6、创建索引的规则
创建索引首先要考虑的是列的可选择性。比较一下列中唯一键的数量和表中记录的行数,就可以判断该列的可选择性。如果该列的“唯一键的数量/表中记录行数”的比值越接近于1,则该列的可选择行越高。在可选择性高的列上进行查询,返回的**就较少,比较适合索引查询。相反,比如性别列上只有两个值,可选择行就很小,不适合索引查询。

第4个回答

用户名:净心素雅  

主要调整存储速度把表设计的更科学使用一些**库技术提速