zoukankan      html  css  js  c++  java
  • 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(撤销授权语句)。

     
  • 相关阅读:
    interview
    lvs简介
    编译参数说明
    nginx-arch
    network
    linux 密码修改方法
    ps命令详解
    sed 命令+正则表达式
    LINUX SCP 命令详解
    linux下mysql的root密码忘记解决方
  • 原文地址:https://www.cnblogs.com/shiyun32/p/9293425.html
Copyright © 2011-2022 走看看