经常发现建立索引后,sql的执行计划不会发生变化,对表运行下述语句后,才能起作用(在plsql 命令窗口中运行)
execute dbms_stats.gather_table_stats(ownname => 'USER_NAME',tabname => 'TABLE_NAME' ,estimate_percent => null ,method_opt => 'for all indexed columns' ,cascade => true ,degree => 1);
索引不起作用的例子
select b.logon_id,
count(logon_id) as shop_count,
max(b.add_date) as last_view_date
from shop_logon_view_pd_info b
group by b.logon_id;
select /*+ index(idx_lvpi_lid_adate)*/
b.logon_id,
count(logon_id) as shop_count,
max(b.add_date) as last_view_date
from shop_logon_view_pd_info b
group by b.logon_id
-- 对于产品访问表shop_logon_view_pd_info做group by统计(记录数,最新日期),由于count这些方法会扫描所有数据行,因此虽然对表建立了logon_id和add_date的组合所以,在oracle CBO还是会自动选择走全表扫描,及时使用hint语法强制指定还是走全表扫描
表fsys_model_param一共有1229993条数据
查询:
select * from fsys_model_param where model_id = '1682'
消耗24.56秒
创建索引
create index idx_fsys_model_param_model_id on fsys_model_param(model_id);
drop index idx_fsys_model_param_model_id on fsys_model_param;
再次查询
select * from fsys_model_param where model_id = '1682'
消耗0.00秒,基本不消耗时间
查看建立的索引:
show index from fsys_model_info;
分享到:
相关推荐
代码复制粘贴 改下里面的参数 就可以用 而且参数 也有说明 简单易懂
一、创建索引 在MySQL中,索引主要分为以下几种类型: 1. 主键索引(Primary Key Index):每个表只能有一个主键,不允许有重复值,且不能为NULL。 2. 唯一索引(Unique Index):与主键类似,唯一索引也确保列中...
Mysql中创建各种索引的语句整理 代码 添加PRIMARY KEY(主键索引) 添加UNIQUE(唯一索引) 添加INDEX(普通索引) 添加FULLTEXT(全文索引) 添加多列索引 ) mysql>ALTER TABLE `...
CREATE INDEX Syntax CREATE [UNIQUE|FULLTEXT|SPATIAL] INDEX index_name [index_type] ON ... HASH | RTREE} 代码如下: — 创建无索引的表格 create table testNoPK ( id int not null, name varchar(10) ); — 创建
创建索引.txt
在MySQL中,索引是一种非常关键的数据库优化技术,它能极大地提升查询效率,尤其是在处理大量数据和复杂查询时。然而,添加索引并非随意为之,而是需要根据实际需求和性能考虑来明智地选择。 首先,理解索引的作用...
创建索引 数据索引 课程目标 理解 —— 创建索引的语法; 掌握 —— 在已有表上创建索引的方法; 掌握 —— 在修改表时添加索引的方法; 掌握 —— 在创建表时创建索引的方法。 创建索引 使用CREATE INDEX语句创建...
### MySQL之Linux安装与索引优化笔记 #### 一、MySQL简介及Linux版安装 **1. MySQL概述** MySQL是一种关系型数据库管理系统(RDBMS),由瑞典MySQL AB公司开发,目前属于Oracle公司。它是一种开源软件,因其性能...
MySQL索引创建详解 MySQL索引是一种提高查询效率的技术,它可以帮助用户快速定位数据。索引可以分为主键索引、唯一索引、普通索引和全文索引四种类型,本文将对每种类型的索引进行详细的介绍。 一、主键索引...
总结起来,MySQL创建索引的方式随着版本的演进越来越优化,以减少对正常服务的影响和提高资源利用率。理解这些方法可以帮助数据库管理员更好地规划和执行索引创建任务,从而提升系统的整体性能和可用性。在实际操作...
在表设计视图中,你可以为每个字段定义属性,其中包括是否设置为主键、唯一约束以及创建索引。选择要建立索引的字段,然后在索引选项中设定索引类型(如主键索引、唯一索引或普通索引),并指定索引的顺序(升序或...
- 直接创建索引:`CREATE INDEX <索引名> ON 表名 (列名列表);` - 修改表添加索引:`ALTER TABLE 表名 ADD INDEX [索引名] (列名列表);` - 创建表时指定索引:`CREATE TABLE 表名 (..., INDEX [索引名] (列名列表...
MySQL索引 聚集索引 如果你想了解MySQL索引查询优化,你首先应该对MySQL数据组织结构、B-Tree索引、聚集索引,次要索引有一定的了解,才能够更好地理解MySQL查询优化行为。这里主要探讨MySQL InnoDB的聚集索引。
MySQL全文索引是一种提高数据库查询性能的技术,尤其适用于大规模文本数据的检索。它通过分词技术和特定的算法,分析文本中的关键词频率和重要性,从而快速定位到匹配的记录。在MySQL中,全文索引主要应用于MYISAM...
在索引优化方面,最左前缀原则是一个关键概念,这意味着复合索引只能按照索引创建时列的顺序部分使用,例如,INDEX(A, B, C)可以用于 WHERE A = x 或 WHERE A = x AND B = y 的查询,但不能单独用于 WHERE B = y 或 ...
MySql创建索引的语法如下: CREATE [UNIQUE|FULLTEXT|SPATIAL] INDEX index_name [USING index_type] ON table_name (index_col_name,…) 其中对应的语法变量信息如下: [UNIQUE|FULLTEXT|SPATIAL]:中括号中的三个...
1. 创建索引:可以使用CREATE INDEX语句或在CREATE TABLE语句中指定INDEX关键字来创建索引。 例如:CREATE INDEX index_name ON table_name (column_name); 或:CREATE TABLE table_name (column1, column2, ..., ...
- **使用复合索引**:通过创建包含多个列的索引,可以同时满足多个查询条件,从而减少索引的数量。 - **定期分析和优化索引**:随着数据的变化,索引的效率也会变化,定期检查和调整索引结构是必要的。 - **利用覆盖...
一般来说,选择WHERE子句中经常使用的列,尤其是连接条件和排序依据的列来创建索引。同时,避免在经常更新的列上建立索引,因为这会增加写操作的复杂性。 关于存储过程,它们是一组预先编译的SQL语句,可以在需要时...