oracle中索引的使用

Posted 一帘幽梦&nn

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了oracle中索引的使用相关的知识,希望对你有一定的参考价值。

声明:以下内容是自己跟着教学视屏学习之后整理而来(主要是自用),如有侵权请告知,将尽快删除。

 

一、索引

1. 概述:
数据库对象之一
索引用于提高查询效率
索引的内建工作对用户是透明的,由数据库自行维护,我们只需要指定是否添加索引。
索引是为表中字段添加的。当一个字段经常出现在WHERE中作为过滤条件,或 ORDER BY 或 DISTINCT中时可以为其添加索引以提高查询效率。

2.索引的使用

(1) 单一索引

--创建索引
CREATE INDEX idx_emp_ename_ning
ON emp(ename)

SELECT ename,job,deptno FROM emp_ning WHERE ename=\'惜月\'

(2) 复合索引:基于多个列的索引

CREATE INDEX idx_emp_job_sal_ning ON emp_ning(job,sal)
SELECT empno,ename,sal,job FROM emp_ning ORDER BY job,sal

(3)创建基于函数的索引

--在emp表的ename列上执行大小写无关的搜索
CREATE INDEX emp_ename_upper_idx_ning ON emp_ning(UPPER(ename))
SELECT * FROM emp_ning WHERE UPPER(ename)=\'惜月\'

(4) 修改和删除索引

a.重建索引:如果经常在索引列上执行DML操作,需要定期重建索引
ALTER INDEX idx_emp_ename_ning REBUILD
b.删除索引
DROP INDEX idx_emp_ename_ning

 

二、结构化查询语言

参考文档:https://www.cnblogs.com/pinnsvin/p/5528272.html

结构化查询语言(sql)可以分为:

a. 数据定义语言(DDL)

b. 操纵语言(DML)

c. 事物控制语言(TCL)

d. 数据查询语言(DQL)

e. 数据控制语言(DCL)

 

1. 数据定义语言(DDL, Data Definition Language)

DDL作用是增删该数据库对象

语法:

a. CREATE:创建数据库对象(数据库对象主要包括:用户、数据库、表、视图、存储过程、存储函数、触发器、索引等);

CREATE TABLE employee_baobao(
  id NUMBER(4),
  name VARCHAR2(20) NOT NULL,
  gender CHAR(1) DEFAULT \'M\',
  birth DATE,
  salary NUMBER(6,2),
  job VARCHAR2(30),
  deptno NUMBER(2)
);

b. ALTER:修改数据库对象;

ALTER TABLE myemp_baobao
ADD(
  hiredate DATE DEFAULT SYSDATE
)
DESC myemp_baobao

b. DROP:删除数据库对象

DROP TABLE employee_baobao

 

2 . 数据查询语言(DQL,Data Query Language)

主要是一些查询的sql语句。

语法:

select * from t1

 

3.数据操纵语言(DML, Data Manipulation Language)

主要是修改表中数据的一些sql语句。

语法结构:

a. INSERT 

INSERT INTO myemp_baobao
  (id,name,job,salary)
VALUES
  (1,\'JACK\',\'MANAGER\',5000)

b. UPDATE

update t_f_prj set f_name = \'xxx\' where pk_id = \'123\'

c. DELETE 

delete from t1 where pk_id = \'123\';

 

4.数据控制语言(DCL, Data Control Language)

主要是用来对数据库权限进行控制。由 GRANT 和 REVOKE 两个指令组成。

a.DCL:控制用户的访问权限;

b. GRANT:授权语句,对应的是REVOKE(撤销授权语句)。

 

以上是关于oracle中索引的使用的主要内容,如果未能解决你的问题,请参考以下文章

sql Oracle代码片段

java.lang.IllegalStateException:键 f0 的片段不再存在:索引 1

c_cpp UV Index Indicator订阅PubNub并使用颜色显示UV索引值。博文的代码片段。在这里查看项目:https:/

Oracle:无效索引列

关于Oracle中索引的使用

活动结果片段索引超出范围:0x20001