Oracle学习笔记之六(DDL:表、索引、视图、同义词、序列操作相关SQL)
下面这些基本的SQL语句应该熟悉,能够灵活运用。最好在不查资料的情况下,能够写出如下的任何代码。
1. 数据表操作相关
--创建表
create table STUDENTS(
STUNO number(10) not null,
STUNAME varchar2(8),
SEX char(2),
AGE int,
DEPARTNO varchar2(2) not null,
CLASSNO varchar2(4) not null,
REGDATE date default sysdate
); --创建表二
create table STUDENTS_2
as select * from STUDENTS; --更改表结构(增加字段)
alter table STUDENTS add(PROVINCE varchar2(10)); --更改表结构(删除字段)
alter table STUDENTS drop column PROVINCE; --更改表结构(删除多字段)
alter table STUDENTS drop(SEX,AGE); --更改表结构(修改字段)
alter table STUDENTS modify DEPARTNO varchar2(4); --重命名表
alter table STUDENTS rename to STUDENTS_NEW; --删除表
--drop table table_name [cascase contraints][purge];
drop table STUDENTS_NEW cascade constraints; --闪回(如果删除的时候加purge参数,则闪回不了了 )
flashback table STUDENTS_NEW to before drop; --修改表的状态(只读)
alter table STUDENTS_NEW read only; --修改表的状态(读写)
alter table STUDENTS_NEW read write;
2. 约束相关
--约束的类型:非空结束、主键结束、唯一约束、外键约束、检查结束和默认约束。
create table BOOKS(
BOOKNO number(4) not null, --非空约束
BOOKNAME varchar2(20),
AUTHOR varchar2(10),
SALEPRICE number(9,2) check(SALEPRICE>0 and SALEPRICE<1000), --检查约束
PUBLISHERNO varchar2(4) not null, --非空约束
PUBLISHDATE date,
ISBN varchar2(20) not null, --非空约束
constraint PK_BOOKS primary key(BOOKNO) --主键约束
); --设置非空约束
alter table BOOKS modify BOOKNAME not null; --去除非空约束
alter table BOOKS modify BOOKNAME null; --去除主键约束
alter table BOOKS drop constraint PK_BOOKS; --设置主键约束
alter table BOOKS add constraint PK_BOOKS primary key(BOOKNO); --设置唯一约束
alter table BOOKS add constraint UQ_BOOKS unique(ISBN); --去除唯一约束
alter table BOOKS drop constraint UQ_BOOKS; --去除外键约束
alter table BBSDISTRICT drop constraint BBSDISTRICT_BBSPROVINCE_FK1; --设置外键约束
alter table BBSDISTRICT add constraint BBSDISTRICT_BBSPROVINCE_FK1
foreign key(PROVINCE_ID)
references BBSPROVINCE(PROVINCE_ID)
on delete set null;--no action/set null/cascade --设置外键约束,如果外键列与被引用表的被引用列列名相同,也可以如下方式定义
alter table BBSDISTRICT add constraint BBSDISTRICT_BBSPROVINCE_FK1
foreign key(PROVINCE_ID)
references BBSPROVINCE; --禁用约束
alter table BBSDISTRICT disable constraint BBSDISTRICT_BBSPROVINCE_FK1; --启用约束
--alter table table_name enable [novalidate|validate] constraint con_name;
--novalidate表示不对表中已经存在的数据进行验证;validate则表示需要对表中已有数据进行验证。
alter table BBSDISTRICT enable constraint BBSDISTRICT_BBSPROVINCE_FK1; --删除约束
--alter table table_name drop constraintcon_name;
alter table BBSDISTRICT drop constraint BBSDISTRICT_BBSPROVINCE_FK1;
3. 其它对象
--创建索引(B树索引,最常用的索引)
create index IX_BBSDETAIL_PRICE on BBSDETAIL(PRICE); --创建位图索引(性别、分类这些重复值非常多的情况下,本情况下一张大表只有7个分类)
create bitmap index IX_BITMAP_BBSDETAIL_CATEGORY on BBSDETAIL(CATEGORY_ID); --建立反向索引,略 --基于函数的索引(将数值字段转化为以十为单位,查询的时候也必须用此函数)
create index IX_BBSDETAIL_CONIS on BBSDETAIL(round(NUMBER_OF_COINS,-1)); --重建索引
alter index IX_BBSDETAIL_PRICE rebuild; --删除索引
drop index IX_BBSDETAIL_CONIS; --创建视图
--create [or replace] view <view_name> [alias[,alias]...]
--as <subquery>
--[with check option][constraint constraint_name]
--[with read only];
create or replace view VIEW_DETAIL
as select CATEGORY_NAME,TITLE,DISTRICT_NAME,ADDRESS from BBSDETAIL,BBSCATEGORY,BBSDISTRICT
where BBSDETAIL.CATEGORY_ID=BBSCATEGORY.CATEGORY_ID and BBSDETAIL.DISTRICT_ID=BBSDISTRICT.DISTRICT_ID
with read only; --查看视图定义
desc VIEW_DETAIL; --重新编译视图
alter view VIEW_DETAIL compile; --删除视图
drop view VIEW_DETAIL; --创建同义词对象(公有)
create public synonym PUBLIC_DETAIL for BBS.BBSDETAIL; --删除同义词对象
drop public synonym PUBLIC_DETAIL; --创建序列
create sequence SEQ_BBSDETAIL
maxvalue 99999
start with 10000
increment by 100
cache 50; --查看当前序列值
select SEQ_BBSDETAIL.currval from dual; --删除序列
drop sequence SEQ_BBSDETAIL;
Oracle学习笔记之六(DDL:表、索引、视图、同义词、序列操作相关SQL)的更多相关文章
- Oracle学习笔记1: 表与约束
1. 登录SQL Plus: 系统用户有哪些: 1. sys,system权限比较高的用户: 2. sysman操作企业管理器使用的. 1.2 的密码是安装oracle是设置的. 3. scott用户 ...
- Oracle学习笔记_04_多表查询
一.概念: 1.多表连接有以下几种分法: (1)内连接 vs 外连接 (左.右.满) (2)等值连接 vs 不等值连接 (3)非自连 ...
- Oracle 学习笔记 11 -- 视图 (VIEW)
本次必须学习一个全新的概念-- 视图 (VIEW).在前面的笔记中曾提到过,数据对象包含:表.视图.序列.索引和同义词.前面的笔记都是对表的想剖析,那么本次笔记就对视图的世界进行深入的剖析. 视图是通 ...
- Oracle 学习笔记 12 -- 序列、索引、同义词
版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/Topyuluo/article/details/24232449 数据库的对象包含:表.视图.序列. ...
- Oracle学习笔记三 SQL命令
SQL简介 SQL 支持下列类别的命令: 1.数据定义语言(DDL) 2.数据操纵语言(DML) 3.事务控制语言(TCL) 4.数据控制语言(DCL)
- Oracle学习笔记—数据字典和常用命令(转载)
转载自: oracle常用数据字典和SQL语句总结 Oracle常用命令大全(很有用,做笔记) 一.Oracle数据字典 数据字典是Oracle存放有关数据库信息的地方,其用途是用来描述数据的.比如一 ...
- Oracle学习笔记之四,SQL语言入门
1. SQL语言概述 1.1 SQL语言特点 集合性,SQL可以的高层的数据结构上进行工作,工作时不是单条地处理记录,而对数据进行成组的处理. 统一性,操作任务主要包括:查询数据:插入.修改和删除数据 ...
- Oracle打怪升级之路二【视图、序列、游标、索引、存储过程、触发器】
前言 在之前 <Oracle打怪升级之路一>中我们主要介绍了Oracle的基础和Oracle常用查询及函数,这篇文章作为补充,主要介绍Oracle的对象,视图.序列.同义词.索引等,以及P ...
- oracle学习笔记第三天
--DML(Data Manipulation Language)--insert关键字 插入 ---语法1.元祖值式插入(一次插入一条记录)---格式:insert into 表名(列名1,列名2. ...
随机推荐
- C++的四种初始化形式以及类型转换
C++中有如下的方式来初始化一个变量. 但当进行类型转换时,只有两种方式可用,其他两种方式会报错.
- 【PHP 】 伪静态 - 3. 伪静态的基本使用
原理图: 原先浏览器输入的网址会发送到apache服务器,然后apache会调用php模块来处理,最后找到你所想访问的页面; 如果在apahce, httpd.conf文件中开启rewrite机制,则 ...
- [Node.js]27. Level 5: URL Building & Doing the Request
Let's create a page which calls the twitter search API and displays the last few results for Code Sc ...
- java编程思想 第四版 第六章 个人练习
欢迎加群:239063848 进群须知:本群仅用于技术分享与交流.问题公布与解答 禁止闲聊.非诚勿扰 练习1:(1)在某个包中创建一个类,在这个类所处的包的外部创建该类的一个实例. import mi ...
- UITableViewAutomaticDimension
tableView.rowHeight = UITableViewAUtomaticDimension UITableViewAutomaticDimension is the default val ...
- 设置TreeView背景色
以下为在Csdn上找到的Treeview资源管理器代码,怎样改变其背景色?用:SendMessage SysTreeWindow,TVM_SETBKCOLOR,0,byval RGB(255,255, ...
- ADOX
1.ADOX 概述 Microsoft ActiveX Data Objects Extensions for Data Definition Language and Security (ADOX) ...
- 对opencv MeanShift 融合矩形框的改进
OPENCV 中的代码改进.当然要依据自己的实际情况来,OPENCV 中行人检測有两种矩形框的融合算法.这里仅仅对meanshift 方法做改进 假设有更好的方法.希望能够跟我讲下. 对于去除重合部分 ...
- 零基础学软件测试V2.0
关于本教程 本系列是在之前的基础上进行了修改更新,原来的内容显得过于简单,但都是重点,这次对于过于简单部分增加了更详细的内容. 目前国内越来越重视软件测试,人才的缺口也是比较大的,为了帮助大家快速的学 ...
- 【laravel54】详解中间件
1.中间件定义:对http请求进行一层过滤,通过过滤才能继续执行请求 2.中间件方法handle方法参数详解: 其中参数的形式可以有多个,使用[,]进行分割. 3.路由中使用中间件: 3.1 中间件使 ...