oracle中索引的使用

时间:2021-12-25 22:31:23

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

一、索引

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 = ''

c. DELETE

delete from t1 where pk_id = '';

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

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

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

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