1500字范文,内容丰富有趣,写作好帮手!
1500字范文 > oracle hint用索引 oracle数据库使用hint来让模糊查询走索引

oracle hint用索引 oracle数据库使用hint来让模糊查询走索引

时间:2022-04-25 06:25:19

相关推荐

oracle hint用索引 oracle数据库使用hint来让模糊查询走索引

在没有创建数据直方图之前,查询优化器是cbo,可能不会选择代价最低(效率最高)的方式查询.

先创建表

--日语假名表

CREATE TABLE JAPANESE_SOUNDMARK

(

ID INTEGER PRIMARY KEY,

ROMAJI VARCHAR2(10),

PHONETIC_SYMBOL VARCHAR(20)

);

创建序列

--创建自增长的序列,用于主键

CREATE SEQUENCE SEQ_JAPANESE_SOUNDMARK

START WITH 1

NOMAXVALUE

INCREMENT BY 1

NOCYCLE

CACHE 10;

创建反向键索引

--给需要模糊查询的列加上反向键索引

CREATE INDEX ROMAJI_REVERSE_INDEX ON JAPANESE_SOUNDMARK(ROMAJI) REVERSE;

创建普通索引

--普通索引

CREATE INDEX PHONETIC_SYMBOL_INDEX ON JAPANESE_SOUNDMARK(PHONETIC_SYMBOL);

注意:

以上语句均为DDL(Data Definition Language)语句,会自动提交事务,如果之前有DML(Data Manipulation Language)语句运行了,但没提交事务,会将之前所有的DML语句也提交事务,ROLLBACK会失效.

1.没有索引时(实际上不需要测试)

--模糊查询,等值

EXPLAIN PLAN FOR

SELECT * FROM JAPANESE_SOUNDMARK

WHERE PHONETIC_SYMBOL LIKE A;

--查看执行计划

SELECT * FROM TABLE(DBMS_XPLAN.DISPLAY);

运行结果:

显而易见:全表扫描

这个其实不需要测试,因为没有索引只能走全表扫描,所以,like \%字符串和like字符串%都是全表扫描.

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。