声明:以下内容是自己跟着教学视屏学习之后整理而来(主要是自用),如有侵权请告知,将尽快删除。
一、索引
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(撤销授权语句)。