当前位置: 首页 > wzjs >正文

宜宾建设教育培训中心网站营销渠道的概念

宜宾建设教育培训中心网站,营销渠道的概念,北京市建设工程交易服务中心网站,搭建wordpress站点一、索引 索引原理 索引介绍 索引是数据库对象之一,用于加快数据的检索,类似于书籍的索引。在数据库中索引可以减少数据库程序查询结果时需要读取的数据量,类似于在书籍中我们利用索引可以不用翻阅整本书即可找到想要的信息。 索引是建立在…

一、索引

索引原理

索引介绍

  • 索引是数据库对象之一,用于加快数据的检索,类似于书籍的索引。在数据库中索引可以减少数据库程序查询结果时需要读取的数据量,类似于在书籍中我们利用索引可以不用翻阅整本书即可找到想要的信息。

  • 索引是建立在表上的可选对象;索引的关键在于通过一组排序后的索引键来取代默认的全表扫描检索方式,从而提高检索效率

  • 索引在逻辑上和物理上都与相关的表和数据无关,当创建或者删除一个索引时,不会影响基本的表;

  • 索引一旦建立,在表上进行DML操作时(例如在执行插入、修改或者删除相关操作时),oracle会自动管理索引,索引删除,不会对表产生影响

  • 索引对用户是透明的,无论表上是否有索引,sql语句的用法不变

  • oracle创建主键时会自动在该列上创建索引

索引的工作机制

  • 若没有索引,搜索某个记录时(例如查找name=‘wish’)需要搜索所有的记录,因为不能保证只有一个wish,必须全部搜索一遍

  • 若在name上建立索引,oracle会对全表进行一次搜索,将每条记录的name值哪找升序排列,然后构建索引条目(name和rowid),存储到索引段中,查询name为wish时即可直接查找对应地方

  • 创建了索引并不一定就会使用,oracle自动统计表的信息后,决定是否使用索引,表中数据很少时使用全表扫描速度已经很快,没有必要使用索引

索引的使用

创建索引语法

CREATE [UNIQUE] | [BITMAP] INDEX index_name  --unique表示唯一索引
ON table_name([column1 [ASC|DESC],column2    --bitmap,创建位图索引
[ASC|DESC],] | [express])
[TABLESPACE tablespace_name]
[PCTFREE n1]                                 --指定索引在数据块中空闲空间
[STORAGE (INITIAL n2)]
[NOLOGGING]                                 --表示创建和重建索引时允许对表做DML操作,默认情况下不应该使用
[NOLINE]
[NOSORT];                                    --表示创建索引时不进行排序,默认不适用,如果数据已经是按照该索引顺序排列的可以使用

管理索引

重命名索引

alter index index_sno rename to bitmap_index;

合并索引(表使用一段时间后在索引中会产生碎片,此时索引效率会降低,可以选择重建索引或者合并索引,合并索引方式更好些,无需额外存储空间,代价较低)

alter index index_sno coalesce;

重建索引

方式一:删除原来的索引,重新建立索引方式二:alter index index_sno rebuild;

删除索引

drop index index_sno;

查看索引

select index_name,index_type, tablespace_name, uniqueness from all_indexes where table_name ='tablename';

索引分类

B-tree索引

  • 默认索引,保存讲过排序过的索引列和对应的rowid值
  • oracle中最常用的索引;B树索引就是一颗二叉树;叶子节点(双向链表)包含索引列和指向表中每个匹配行的ROWID值
  • 所有叶子节点具有相同的深度,因而不管查询条件怎样,查询速度基本相同
  • 适用于等值查询、范围查询
  • UNIQUE,NON-UNIQUE(默认),REVERSE KEY(数据列中的数据是反向存储的)
  • 适用场景: 列基数(列不重复值的个数)大时适合使用B数索引

位图索引(Bit MAP索引)

  • 创建位图索引时,oracle会扫描整张表,并为索引列的每个取值建立一个位图(位图中,对表中每一行 使用一位(bit,0或者1)来标识该行是否包含该位图的索引列的取值,如果为1,表示对应的rowid所在的记录包含该位图索引列值),最后通过位图索 引中的映射函数完成位到行的ROWID的转换。
  • 适合场景:对于基数小的列适合简历位图索引(例如性别等)
  • 对于频繁更新的表,不适合创建位图索引

复合索引

  • 基于多个列创建
  • 即如果索引建立在多个列上,只有它的第一个列被where子句引用时,优化器才会使用该索引,即至少要包含组合索引的第一列
  • 合适的使用复合索引,可以有效的避免索引回表,大大降低随进读和逻辑读
  • 复合索引占用的空间会多一些

函数索引

  • 当经常要访问一些函数或者表达式时,可以将其存储在索引中,这样下次访问时,该值已经计算出来了,可以加快查询速度

  • 函数索引既可以使用B数索引,也可以使用位图索引;当函数结果不确定时采用B树索引,结果是固定的某几个值时使用位图索引

  • 函数索引中可以水泥用len、trim、substr、upper(每行返回独立结果),不能使用如sum、max、min、avg等

索引使用方法论

索引创建规则

  • 如果有两个或者以上的索引,其中有一个唯一性索引,而其他是非唯一,这种情况下oracle将使用唯一性索引而完全忽略非唯一性索引

  • 至少要包含组合索引的第一列(即如果索引建立在多个列上,只有它的第一个列被where子句引用时,优化器才会使用该索引)

  • 小表不需要建立索引

  • 对于基数大的列适合建立B树索引,对于基数小的列适合简历位图索引

  • 列中有很多空值,但经常查询该列上非空记录时应该建立索引

  • 经常进行连接查询的列应该创建索引

  • 使用create index时要将最常查询的列放在最前面

  • LONG(可变长字符串数据,最长2G)和LONG RAW(可变长二进制数据,最长2G)列不能创建索引

  • 限制表中索引的数量(创建索引耗费时间,并且随数据量的增大而增大;索引会占用物理空间;当对表中的数据进行增加、删除和修改的时候,索引也要动态的维护,降低了数据的维护速度)

不使用索引的场景

测试表T1在id和name列上有索引

  • 通配符在搜索词首出现时,oracle不能使用索引
SQL> select * from t1 where name like '%aa%';Execution Plan
----------------------------------------------------------
Plan hash value: 3617692013--------------------------------------------------------------------------
| Id  | Operation         | Name | Rows  | Bytes | Cost (%CPU)| Time     |
--------------------------------------------------------------------------
|   0 | SELECT STATEMENT  |      |     1 |    20 |     3   (0)| 00:00:01 |
|*  1 |  TABLE ACCESS FULL| T1   |     1 |    20 |     3   (0)| 00:00:01 |
--------------------------------------------------------------------------
---如果通配符出现在字符串的其他位置时,优化器能够利用索引
SQL> select * from t1 where name like 'aa%';Execution Plan
----------------------------------------------------------
Plan hash value: 2389066551-------------------------------------------------------------------------------------------------
| Id  | Operation                           | Name      | Rows  | Bytes | Cost (%CPU)| Time     |
-------------------------------------------------------------------------------------------------
|   0 | SELECT STATEMENT                    |           |     1 |    20 |     2   (0)| 00:00:01 |
|   1 |  TABLE ACCESS BY INDEX ROWID BATCHED| T1        |     1 |    20 |     2   (0)| 00:00:01 |
|*  2 |   INDEX RANGE SCAN                  | INDX_NAME |     1 |       |     1   (0)| 00:00:01 |
-------------------------------------------------------------------------------------------------
  • 不要在索引列上使用not,可以采用其他方式代替如下:(oracle碰到not会停止使用索引,而采用全表扫描)
SQL> select * from t1 where not (id=2);Execution Plan
----------------------------------------------------------
Plan hash value: 3617692013--------------------------------------------------------------------------
| Id  | Operation         | Name | Rows  | Bytes | Cost (%CPU)| Time     |
--------------------------------------------------------------------------
|   0 | SELECT STATEMENT  |      |     4 |    80 |     3   (0)| 00:00:01 |
|*  1 |  TABLE ACCESS FULL| T1   |     4 |    80 |     3   (0)| 00:00:01 |
SQL> select * from t1 where id <>2;Execution Plan
----------------------------------------------------------
Plan hash value: 3617692013--------------------------------------------------------------------------
| Id  | Operation         | Name | Rows  | Bytes | Cost (%CPU)| Time     |
--------------------------------------------------------------------------
|   0 | SELECT STATEMENT  |      |     4 |    80 |     3   (0)| 00:00:01 |
|*  1 |  TABLE ACCESS FULL| T1   |     4 |    80 |     3   (0)| 00:00:01 |
--------------------------------------------------------------------------
  • 索引上使用空值比较将停止使用索引

    SQL> select * from t1 where name is null;no rows selectedExecution Plan
    ----------------------------------------------------------
    Plan hash value: 3617692013--------------------------------------------------------------------------
    | Id  | Operation         | Name | Rows  | Bytes | Cost (%CPU)| Time     |
    --------------------------------------------------------------------------
    |   0 | SELECT STATEMENT  |      |     1 |    20 |     3   (0)| 00:00:01 |
    |*  1 |  TABLE ACCESS FULL| T1   |     1 |    20 |     3   (0)| 00:00:01 |
    --------------------------------------------------------------------------
    
http://www.dtcms.com/wzjs/373999.html

相关文章:

  • css建设网站的步骤aso优化吧
  • wordpress主题没有小工具360优化大师
  • 深圳网站建设报价互联网营销的方式有哪些
  • 北京网站开发网站建设报价电脑培训班速成班
  • 大连网站建设辽icp备谷歌搜索网址
  • 张家港网站建设模板宁波网站建设与维护
  • 三星单片机开发网站百度认证平台官网
  • 河北住房与建设信息网站seo入门书籍
  • 厦门网站建设合同旅游搜索量环比增188%
  • 个人怎样做旅游网站谷歌推广运营
  • 贵阳城乡建设学校网站推广平台网站
  • 做一个类似微博的网站需要怎麼做百度竞价渠道代理商
  • 唐山做网站的公司关键词排名手机优化软件
  • 网店托管靠谱吗seo销售话术开场白
  • 网站添加 百度商桥武汉网络推广自然排名
  • 一个网站用多个域名西安网站到首页排名
  • 电子商务网站建设的问题营销策划的十个步骤
  • 网站建设与管理asp网站建设详细方案
  • 儿童主题网站的内容建设泉州全网营销推广
  • 无锡专业做网站的公司哪家好网络推广销售是做什么的
  • 巴士定制网站开发拉新app渠道
  • php大型综合网站源码怎么快速刷排名
  • 万网 网站 流程郑州靠谱seo电话
  • 全国做网站找哪家好百度竞价推广什么意思
  • 国外jquery网站搜索引擎优化推广
  • 安装宝塔之后wordpress首页打不开西安百度推广优化托管
  • 广州网站托管百度框架户开户渠道
  • 购物网站服务器硬件配置长春网站建设技术支持
  • 北京电力交易中心主任优化营商环境的措施建议
  • 富阳网站seo价格网络广告营销典型案例