下面这些基本的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)的更多相关文章

  1. Oracle学习笔记1: 表与约束

    1. 登录SQL Plus: 系统用户有哪些: 1. sys,system权限比较高的用户: 2. sysman操作企业管理器使用的. 1.2 的密码是安装oracle是设置的. 3. scott用户 ...

  2. Oracle学习笔记_04_多表查询

    一.概念: 1.多表连接有以下几种分法: (1)内连接           vs          外连接 (左.右.满) (2)等值连接        vs         不等值连接 (3)非自连 ...

  3. Oracle 学习笔记 11 -- 视图 (VIEW)

    本次必须学习一个全新的概念-- 视图 (VIEW).在前面的笔记中曾提到过,数据对象包含:表.视图.序列.索引和同义词.前面的笔记都是对表的想剖析,那么本次笔记就对视图的世界进行深入的剖析. 视图是通 ...

  4. Oracle 学习笔记 12 -- 序列、索引、同义词

    版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/Topyuluo/article/details/24232449 数据库的对象包含:表.视图.序列. ...

  5. Oracle学习笔记三 SQL命令

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

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

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

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

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

  8. Oracle打怪升级之路二【视图、序列、游标、索引、存储过程、触发器】

    前言 在之前 <Oracle打怪升级之路一>中我们主要介绍了Oracle的基础和Oracle常用查询及函数,这篇文章作为补充,主要介绍Oracle的对象,视图.序列.同义词.索引等,以及P ...

  9. oracle学习笔记第三天

    --DML(Data Manipulation Language)--insert关键字 插入 ---语法1.元祖值式插入(一次插入一条记录)---格式:insert into 表名(列名1,列名2. ...

随机推荐

  1. 使用sed进行文字替换

    范式: sed -i "s/查找内容/替换后内容/g" `grep 查找内容 -rl 查找开始路径` 例子: #sed -i "s/abc/ABC/g" `gr ...

  2. Java从零开始学三十五(JAVA IO- 字节流)

    一.字节流 FileOutputStream是OutputStream 的直接子类 FileInputStream也是InputStream的直接子类 二.文本文件的读写 2.1.字节输入流 Test ...

  3. 把Linux目录挂载到开发板、设置开发板从NFS启动、取消开发板从NFS启动

    声明:文中"PC虚拟机Linux"是指在PC上安装了虚拟机,然后在虚拟机中装的Linux. 关于NFS的详细介绍可参考:http://www.cnblogs.com/nufangr ...

  4. 恭喜您成为2014年度Microsoft MVP!

  5. 通过jdbc使用PreparedStatement,提升性能,防止sql注入

    为什么要使用PreparedStatement? 一.通过PreparedStatement提升性能 Statement主要用于执行静态SQL语句,即内容固定不变的SQL语句.Statement每执行 ...

  6. 3DTouch - iOS新特性

    概述 3DTouch是一种立体触控技术,被苹果称为新一代多点触控技术. 详细 代码下载:http://www.demodashi.com/demo/10708.html 6s和6s plus之后特有效 ...

  7. openvpn服务端一键生成windows,macos客户端配置文件

    #!/bin/bash #获取参数 while getopts "n:" opt; do case $opt in n) client_name=$OPTARG ;; \?) ;; ...

  8. 配置eclipse插件

    http://blog.csdn.net/zhangyabinsky/article/details/7043435

  9. HDUOJ--1865 1string

    1sting Time Limit: 5000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Subm ...

  10. Foundations of Machine Learning: Rademacher complexity and VC-Dimension(2)

    Foundations of Machine Learning: Rademacher complexity and VC-Dimension(2) (一) 增长函数(Growth function) ...