DCL 数据控制语言 Data control language

之前说过的授权和收权利语句

grant, revoke

DDL 数据定义语言 Data define language

create alter,drop语句,创表,修改表,删除

创建表

create table $tablename$(
id int,
name varchar2(5) --需要声明最大长度
money number(6,2) --9999.00
--最后不能有逗号,否则会创表失败
)
/*
把其他的表的内容与结构复制生成一个新表,新表没有约束
将其它表的数据二复制到新表中(新表事先 不存在)
新表具有与查询的表格基本相同的结构,但不会有约束(主键、外键、默认约束..)。
*/
create table $tablename$ as $othertablename$ -- 把查询的结果的内容和结构生成一个新表
create table $tablename$ as select * from student

查看表结构

desc $tablename$

修改表

添加约束

约束用于限制加入表中的数据的合法性:

    1. NOT NULL:非空约束
    1. UNIQUE :唯一约束 UN_表名_列名 规范格式
    1. PRIMARY KEY :主键约束 PK_表名_列名
    1. FOREIGN KEY :外键约束 FK_表名_列名
    1. CHECK :检查约束 CHK_表名_列名
    1. DEFAULT :默认约束 DF_表名_列名

1.默认约束

alter table $tablename$ modify (列名 default 默认值);
--例
alter table student modify (age default 18);

2.唯一约束

alter table $tablename$ add constraint UN_$tablename_$columnname$ unique(列名)
--例
alter table student add constarint UN_student_num unique(num);

3.主键约束

alter table $tablenamae$ add constraint PK_$tablename_$columnname$ primary key(列名);
--例
alter table student add constraint PK_student_num primary key(num);
--复合主键(联合主键)
alter table student add constraint PK_student_numandage primary key(num,age);

4.检查约束

alter table $tablename$ add constraint CHK_$tablename_$columnname$ check(条件);--条件 且and  或or
--例
alter table student add constraint CHK_student_age check(age>=18 and age<=22);

5.外键约束

存在外键的表称为外键表

被外键引用的表称为主键表

  • no action(默认)

    删除主键表的某一数据,会拒绝删除,需要先删除外键表中引用了主键表某个数据的那些数据,才能删除主键表的该条数据
  • cascade 级联删除

    当删除主键表的某条数据,外键表引用了主键表的该数据的所有数据都会一起删除
  • set null

    当删除主键表的某条数据,外键表引用了主键表的该数据的所有数据的该列都会设置为null
alter table tablename add constraint FK_ foreign key() references () [on delete cascade/set null]

cascade update 级联更新类似

删除约束

alter table $tablename$ drop constraint 约束名
--例
alter table student drop CHK_student_age;

禁用约束

alter table $tablename$ disable constraint 约束名
--例
alter table student disable constraint CHK_student_age;

修改表名

--修改表名
alter table $oldtablename$ rename to $newtablename$;

添加列

alter table $tablename$ add $列名$ $数据类型$;

删除列

alter table $tablename$ drop column $列名$;

修改列(列数据类型或数据最大长度)

alter table $tablename$ modify $列名$ $数据类型$

创建表同时加入约束条件

create table $tablename$(
id int,
name,varchar(5),
money,number(6,2),
constraint pk_CK check...
) --这一种不能指定约束名,而是系统自动生成的约束名,删除的时候比较麻烦
create table $tablename(
id int not null primary key,
name varchar(5),
)

删除表

drop table $tablename$ --删除的表放入回收站中
drop table $tablename$ purge --彻底删除表
show recyclebin; --在PLSQL Developer中看不见,需要在sqlplus窗口执行
purge recyclebin; --清空回收站

删除表数据但不删除表结构

truncate table $tablename$;

恢复表

flashback table $tablename$ to before drop;

oracle学习笔记(三) DCL 数据控制语言与 DDL 数据定义语言的更多相关文章

  1. Oracle学习笔记三 SQL命令

    SQL简介 SQL 支持下列类别的命令: 1.数据定义语言(DDL) 2.数据操纵语言(DML) 3.事务控制语言(TCL) 4.数据控制语言(DCL)  

  2. Oracle学习笔记三

    一.创建表空间 表空间是ORACLE数据库的逻辑单元.数据库--表空间 一个表空间可以与多个数据文件(物理结构)关联一个数据库下可以建立多个表空间,一个表空间可以建立多个用户个用户下可以建立多个表. ...

  3. oracle 学习笔记(三)

    1. SQL(基础查询) 1.1. 基本查询语句 1.1.1. FROM子句 SQL查询语句的语法如下:   SELECT <*, column [alias], -> FROM tabl ...

  4. Oracle学习笔记(三)

    五.操作表 1.表分为行和列 约定:每行数据唯一性,每列数据同类性,每列列名唯一性. 2.数据类型 字符型 -- 固定长度的字符类型 字符类型:CHAR(n)(MAX n=2000).NCHAR(MA ...

  5. Oracle学习笔记一

    Oracle数据库的体系结构 数据库: database Oracle数据库是数据的物理存储.这就包括(数据文件ORA或者DBF.控制文件.联机日志.参数文件).其实 Oracle数据库的概念和其它数 ...

  6. Oracle学习笔记之四,SQL语言入门

    1. SQL语言概述 1.1 SQL语言特点 集合性,SQL可以的高层的数据结构上进行工作,工作时不是单条地处理记录,而对数据进行成组的处理. 统一性,操作任务主要包括:查询数据:插入.修改和删除数据 ...

  7. oracle学习笔记第一天

    oracle学习笔记第一天 --oracle学习的第一天 --一.几个基础的关键字   1.select select (挑选) 挑选出显示的--列--(可以多列,用“,”隔开,*表示所有列),为一条 ...

  8. Oracle学习笔记—数据字典和常用命令(转载)

    转载自: oracle常用数据字典和SQL语句总结 Oracle常用命令大全(很有用,做笔记) 一.Oracle数据字典 数据字典是Oracle存放有关数据库信息的地方,其用途是用来描述数据的.比如一 ...

  9. [Firefly引擎][学习笔记三][已完结]所需模块封装

    原地址:http://www.9miao.com/question-15-54671.html 学习笔记一传送门学习笔记二传送门 学习笔记三导读:        笔记三主要就是各个模块的封装了,这里贴 ...

随机推荐

  1. ajax 和jsonp 不是一码事

    由于Sencha Touch 2这种开发模式的特性,基本决定了它原生的数据交互行为几乎只能通过AJAX来实现. 当然了,通过调用强大的PhoneGap插件然后打包,你可以实现100%的Socket通讯 ...

  2. 我手写的简易tomcat

    前述 自己手写的简易的tomcat,实现了tomcat的基本响应功能,项目代码已经上传到我的Github,刚刚开始学习这里,当前还存在很多问题 项目简述及代码 当我们的Web运行的时候,从浏览器发出的 ...

  3. Windows环境下消息中间件RabbitMq的搭建与应用

    前言 消息中间件目前已经在很多大型的项目上得到了运用,我们常见的有 RabbitMq, activitymq,kafka,rocketmq,其中rocketmq是阿里自己在kafka的基础上用java ...

  4. Python:轻量级 ORM 框架 peewee 用法详解(二)——增删改查

    说明:peewee 中有很多方法是延时执行的,需要调用 execute() 方法使其执行.下文中不再特意说明这个问题,大家看代码. 本文中代码样例所使用的 Person 模型如下: class Per ...

  5. 入门系列之Scikit-learn在Python中构建机器学习分类器

    欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 本文由信姜缘 发表于云+社区专栏 介绍 机器学习是计算机科学.人工智能和统计学的研究领域.机器学习的重点是训练算法以学习模式并根据数据进行预 ...

  6. C# 替换Word文本—— 用文档、图片、表格替换文本

    编辑文档时,对一些需要修改的字符或段落可以通过查找替换的方式,快速地更改.在C# 在word中查找及替换文本一文中,主要介绍了在Word中以文本替换文本的方法,在本篇文章中,将介绍如何用一篇Word文 ...

  7. CSS消除button标签的默认样式

    button{ /*消除button的默认样式*/ /*这种写法是对所有的button标签同时生效*/ margin: 0px; padding: 0px; /*自定义边框*/ border: 0px ...

  8. linux中添加快捷命令

    例如我们需要ssh的时候,每次都要ssh ninetripod@10.0.0.11 -p 12345,这样显然很麻烦. 我们可以vim ~/.bashrc在里面添加alias ssh_='ssh ni ...

  9. 快速构建H5单页面切换应用

    在Web App和Hybrid App横行的时代,为了拥有更好的用户体验,单页面应用顺势而生,单页面应用简称`SPA`,即Single Page Application,就是只有一个HTML页面的应用 ...

  10. Php如何返回json数据,前后端分离的基本解决方案

    php返回json,xml,JSONP等格式的数据 返回json数据: header('Content-Type:application/json; charset=utf-8'); $arr = a ...