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. ...
随机推荐
- MYSQL 表中汉字写入或字段赋值时乱码情况排误
-- 当改动字段值.或是直接写入时,汉字变成乱码情况 .[可注意一下数据库名,记得改动] -- 当字符顺序对汉字不兼容时,可能直接导致乱码情况发生. 最好做到库.表.字段(字符类型)排序规则是否一致 ...
- rEFind 教程
资料 在空白区右键,新建一个文件,命名为rEFind! 双击进入rEFind文件夹,我们开始搬文件了! 解压refind.zip 创建一个文件,仿照refind.conf-sample写一个文件,命名 ...
- Eclipse中jar包关联JDK源代码
1.点 “window”-> "Preferences" -> "Java" -> "Installed JRES"2.此 ...
- sqlserver 创建对某个存储过程执行情况的跟踪
有时候需要抓取执行存储过程时某个参数的值,有时候程序调用存储过程执行后结果不太对,不确定是程序的问题还是存储过程的问题,需要单独执行存储过程看结果 即可用下面的方法 --=============== ...
- MVC时间对比及时间范围判断
方法一:使用DateTime.Compare 方法 public static int Compare( DateTime t1, DateTime t2 ) t1 早于 t2:小于零t1 与 t2 ...
- grid++ 开发教程
grid++ 开发教程 CreateTime--2018年4月24日18:43:23 Author:Marydon 1.插入报表头.明细网格.报表尾 右键-->插入-->报表节--&g ...
- SettingsPLSQLDeveloper
迁移时间:2017年5月21日10:12:23Author:Marydon 一.常用配置项UpdateTime--2017年3月15日13:55:46注:没有安装Oracle数据库的情况下,前两步 ...
- Oracle单实例启动多个实例
Oracle多实例运行,单个实例就是一个数据库!,一个数据库对应多个实例是RAC Linux建立oracle的实例步骤: 1.在linux服务器的图形界面下,打开一个终端,输入如下的命令: xhost ...
- 交叉编译OpenWrt 定制固件
在Centos7上交叉编译生成OpenWrt固件 安装ss-* 获取最新的ss, 当前是 wget https://github.com/shadowsocks/shadowsocks-libev/a ...
- CSS3+JS 实现的便签应用
概述 利用HTML5新增的 locationStorage 实现的便签应用,没有使用 JQuery,主要是为了练习原生JS的使用,采用响应式开发,在手机端和桌面端都有良好的体验,而且使用CSS3添加了 ...