Oracle--DML、DDL、DCL

DML(data manipulation language):数据操作语言
       它们是select、update、insert、delete,就象它的名字一样

DDL(data definition language):数据定义语言
       主要的命令有create、alter、drop、truncate等,DDL主要是用在定义或改变表(TABLE)的结构,数据类型,表之间的链接和约束等初始化工作上,他们大多在建立表时使用

DCL(Data Control Language):数据控制语言。
    是用来设置或更改数据库用户或角色权限的语句,包括(grant,deny,revoke等)语句。在默认状态下,只有sysadmin,dbcreator,db_owner或db_securityadmin等人员才有权力执行DCL

详细解释:
一、DDL:数据定义语言(没有delete,下面只是为了方便用了delete!!!!)

      1.1.、表的创建和删除

--供应商表
CREATE TABLE s (s_no VARCHAR(5) NOT NULL, --供应商代码
                s_name VARCHAR(30) UNIQUE,  --供应商名
                s_status VARCHAR(20),  --供应商状态
                PRIMARY KEY(s_no));  

--零件表              
CREATE TABLE p (p_no VARCHAR(5) NOT NULL PRIMARY KEY,  --零件号
                p_name VARCHAR(30) UNIQUE,  --零件名
                p_weight NUMERIC(6,2),  --重量
                p_city VARCHAR(20)  --产地 );   

--关系模式:一个供应商可以供应多个零件,而一个零件可以由多个供应商供应 s_p(s_no, p_no, quantity)                
CREATE TABLE s_p (s_no VARCHAR(5),
                  p_no VARCHAR(5),
                  quantity NUMERIC(9),  --数量
                  PRIMARY KEY(s_no, p_no),
                  FOREIGN KEY(s_no) REFERENCES s (s_no),
                  FOREIGN KEY(p_no) REFERENCES p (p_no));

--需要注意的地方:
--1、如果已经定义的主键,如PRIMARY KEY(s_no),则不能在s_no之后加unique,不然有错误
--2、foreign key(s_no) references s(s_no)定义了在s_p关系中s_no为外码,其取值必须来自s关系的s_no域
    1.1.1、操作表、列

--在s_no表添加一列 s_city; oracle中不能在某列前后固定插入,只会在最后列中追加
--插入新列不影响前面的数据
ALTER TABLE s ADD s_city VARCHAR2(20);

ALTER TABLE s RENAME TO s_table;  --修改表名   

ALTER TABLE s_table RENAME COLUMN s_city TO s_country; --修改表列名

ALTER TABLE s_table MODIFY s_country NUMBER(20);  --修改字段类型

ALTER TABLE s_table DROP COLUMN s_country; --删除表列   

--注意:首先,增加和修改列是不需要加关键字COLUMN,否则会报错ora-00905。
--  其次,对删除单列的话,一定要加COLUMN,然后记住,删除是不需要加列类型的。

-------------------------------------------------------------------------

--增加多列:
ALTER TABLE s_table ADD (test1 VARCHAR2(10),test2 NUMBER);

--修改多列:
ALTER TABLE  s_table MODIFY (test1 VARCHAR2(20),test2 VARCHAR2(20));

--删除多列:
ALTER TABLE s_table DROP (test1,test2);

--很奇怪的现象,再单列中要加关键字COLUMN,然而再删除多列的时候,不能加COLUMN关键字。

    1.2、创建、删除索引

创建索引语句格式:
                create [unique][cluster] index <索引名>
                on <表名>(列名 [<次序>],列名 [<次序>]...);
 unique:表明此索引的每一个索引值只对应唯一的数据记录。
 cluster:表明要建立的索引是聚簇索引,意为索引项的顺序是与表中记录的物理顺序一致的索引组织。
 次序。默认次序是ASC

--建表
CREATE TABLE s_test (s_no VARCHAR(5) NOT NULL, --供应商代码
                s_name VARCHAR(30),  --供应商名
                s_status VARCHAR(20)  --供应商状态
                );                    
 
--建立索引                
CREATE UNIQUE INDEX test_index ON s_test(s_no DESC) ;                      

--Oracle数据库创建表是有两个约束带有默认索引。
--1、主键primary Key:唯一索引、非空
--2、唯一Unique:唯一索引,可以是空值
--如果没有设定主键和唯一约束,表中不会有默认索引的,这时才可以建立索引!!!。

--查看索引。一定是大写的表名
SELECT * FROM User_Indexes  WHERE table_name = 'S_TEST';  

--删除索引
DROP INDEX test_index;

1.3、视图的创建、删除
视图创建语法:
           create view 视图名(列表名)
           as select 查询子句
           [with check option];
注意:1、子查询是任意复杂的 select 语句,但通常不允许含有 order by子句和distinct 语句
          2、with check option 表示对update、insert、delete操作时保证更新、插入或删除的行为满足子查询的条件表达式

--创建视图时需要权限, system用户有两种方式给权限                    
GRANT CREATE ANY VIEW TO changwen;

GRANT CONNECT, RESOURCE,DBA TO changwen;  

--创建视图
CREATE VIEW s_view
AS SELECT s_no, s_name FROM s_table; 

--删除视图
DROP VIEW s_view;
1.4、delete 与 truncate 区别?
1) truncate 是DDL语句,delete 是DML语句;
2) truncate 比delete删除速度快,效率高,主要原因是truncate 使用的系统和事务日志资源少。;
   具体原因:1、当我们执行delete操作时所有表数据先被copy到回滚表空间,数据量不同花费时间长短不一。
                     而truncate是直接删除数据不进回滚表空间。
             2、DELETE 语句每次删除一行,并在事务日志中为所删除的每行记录一项。
               TRUNCATE 通过释放存储表数据所用的数据页来删除数据,并且只在事务日志中记录页的释放。
3)接(2)这也就导致了 delete数据后我们可以运行rollback进行数据回滚,而truncate则是永久删除不能回滚
4)由于truncate table不记录在日志中,所以 truncate 操作不会触发表上的delete触发器;而delete会正常触发
5) truncate语句不能带where条件意味着只能全部数据删除,而delete可删除部分数据;
6)truncate 操作会重置表的高水位线(High Water Mark),而delete不会。
7) 对于由 foreign key 约束引用的表,不能使用 truncate table,而应使用不带 WHERE 子句的 delete语句
8) truncate table 不能用于参与了索引视图的表。
9)truncate  删除表中的所有行,但表结构及其列、约束、索引等保持不变。新行标识所用的计数值重置为该列的种子。
    如果想保留标识计数值,请改用 DELETE。如果要删除表定义及其数据,请使用 DROP TABLE 语句。

1.5、COMMENT--注释

SQL-->COMMENT ON TABLE s_test IS '存放雇员信息';  --没有多大的用

1.6、RANT 赋于权限
常用的系统权限集合有以下三个:
connect(基本的连接),   resource(程序开发),   dba(数据库管理)


常用的数据对象权限有以下五个:
ALL   ON   数据对象名,   
SELECT   ON   数据对象名,  
UPDATE   ON   数据对象名,
DELETE   ON   数据对象名,     
INSERT   ON   数据对象名,       
ALTER    ON   数据对象名

  grant  connect, resource  to   用户名;
 grant  select  on   表名  to   用户名;
 grant  select, insert,  delete  on 表名   to   用户名1,  用户名2;

1.7、revoke   回收权限
  revoke  connect, resource from  用户名;
  revoke  select  on   表名 from  用户名;
  revoke  select, insert,  delete  on 表名  from   用户名1,   用户名2;

二、DML:数据操作语言

       1. SELECT - -    查询
       2. INSERT --     添加
        3. UPDATE --    更新
       4. DELETE --   删除
       5. CALL - call a PL/SQL or Java subprogram
       6.EXPLAIN PLAN - explain access path to data
       Oracle RDBMS执行每一条SQL语句,都必须经过Oracle优化器的评估。所以, 了解优化器是如何选择(搜索)路径以及索引是如何被使用的,对优化SQL语句有很大的帮助。Explain可以用来迅速方便地查出对于给定SQL语句中的查询数据是如何得到的即搜索路径(我们通常称为Access Path)。从而使我们选择最优的查询方式达到最大的优化效果。
       7.LOCK TABLE - control concurrency 锁,用于控制并发

三、DCL:数据控制语言
,用来授予或回收访问数据库的某种特权,并控制数据库操纵事务发生的时间及效果,对数据库实行监视等
       1.COMMIT - save work done 提交
        2.SAVEPOINT - identify a point in a transaction to which you can later roll back 保存点
       3.ROLLBACK - restore database to original since the last COMMIT   回滚
       4.SET TRANSACTION - Change transaction options like what rollback segment to use   设置当前事务的特性,它对后面的事务没有影响

你可能感兴趣的:(oracle,DDL,DML,DCL)