Orcale 之 SQL 数据定义
CREATE
在数据库中对数据对象的创建使用的是 CREATE 语句来完成。
创建表
在使用数据库的时候经常用到的就是对表的创建。SQL 语句使用 CREATE TABLE 进行创建。基本语法如下:CREATE TABLE <table_name>(
<colum_name><data_type>[column_constraint_name],
<colum_name><data_type>[column_constraint_name]...
[table_constraint_name]
)上面的<table_name> 是定义的表的名字,它可以有一个或者多个属性组成。在创建表的时候我们通常还会对某个属性添加约束条件,这些约束条件会存放在数据字典中,当用户对表中的数据进行操作的时候,DBMS会自动的检查该操作是否符合完整性约束。看一下的例子:创建一个员工表,由员工的员工号(ID),员工的姓名(Name),员工邮箱(Email),员工的电话(Phone),员工所属的部门编号(DepID),员工的薪资(Salary)以及项目经理编号(ManagerID),我们知道每个员工都会有自己的编号并且是唯一的。CREATE TABLE TEmployees(
EId Number(6) not null unique,
EName varchar2(20),
EEmail varchar2(20),
EPhone varchar2(20),
EdepId varchar2(10),
ESalary Number(8,2),
EManagerId Number(6)
);以上的 SQL 语句为我们创建了一个员工的表 TEmployees, 并将员工表的定义和约束放入了数据字典。创建视图
视图是从一个或者几个表导出的表,它是一个虚表。在数据库中只存在视图的定义,而不会有关视图的数据,这些数据还是存放在原来的表中,所以当基表中的数据发生变化那么视图中的数据也会发生变化。一下是创建视图的语法:CREATE VIEW <view_name>[
(
<column_name>
[,column_name]...
) ]AS <children_query>
[WITH CHECK OPCTION]其中的子查询不能包含 ORDER BY 和 DISTINCT 等复杂的查询语句的。WITH CHECK OPCTION 表示在对视图进行 UPDATE, INSERT 和 DELETE 这些操作的时候要满足子查询中的表达式。如下例子 创建以上我们创建的 TEmployees b表的视图 条件为:EdepId = 'DEV'CREATE VIEW VEmployees_1
AS SELECT EId, EName, EEmail, EPhone, EdepId, ESalary, EManagerId
FROM TEmployees
WHERE EdepId = 'DEV';
--WITH CHECK OPCTION同理这个视图 VEmployees_1 的定义会存储数据字典中,但是这里要注意的是并没有执行 SELECT 语句,只有当对这个视图进行查询的时候才会去基表中队数据进行查询,再将其返回出去,因此我们可以把视图看成基表的一种快捷方式。如果我们使用 WITH CHECK OPCTION 那么在以后对视图进行增删改的时候 DBMS 会自动的检查 EdepId = 'DEV'。创建索引
只有表或视图的所有者才能为表创建索引。表或视图的所有者可以随时创建索引,无论表中是否有数据。可以通过指定限定的数据库名称,为另一个数据库中的表或视图创建索引。不多说直接看语法:
CREATE [ UNIQUE ] [ CLUSTERED | NONCLUSTERED ] INDEX index_name
ON { table | view } ( column [ ASC | DESC ] [ ,...n ] )UNIQUE 为表或视图创建唯一索引(不允许存在索引值相同的两行)。视图上的聚集索引必须是 UNIQUE 索引。[ ASC | DESC ] 确定具体某个索引列的升序或降序排序方向。默认设置为 ASC。CREATE INDEX Employees_Name on TEmployees(EName);
为表 TEmployees 的 EName 创建索引 Employees_Name 并按照升序排列。
DROP
删除数据表
删除表定义及该表的所有数据、索引、触发器、约束和权限规范。任何引用已除去表的视图或存储过程必须通过 DROP VIEW 或 DROP PROCEDURE 语句显式除去。语法如下:DROP TABLE <table_name>;
注意: DROP TABLE 不能用于除去由 FOREIGN KEY 约束引用的表。必须先除去引用的 FOREIGN KEY 约束或引用的表。删除数据表后基于这个表创建的视图不会被删除,当引用这个视图的是还会报错。DROP TABLE TEmployees;
删除视图
从当前数据库中删除一个或多个视图。可对索引视图执行 DROP VIEW。语法如下:DROP VIEW { view } [ ,...n ];view 表示要删除的视图名,n 表示可以删除多个视图的占位符。删除索引
从当前数据库中删除一个或多个索引。语法如下:DROP INDEX 'table.index | view.index' [ ,...n ];
table | view 索引列所在的表或索引视图。index 是要除去的索引名称。n 是指多个索引的占位符。DROP INDEX Employees_Name 删除 Employees_Name 索引。
ALTER
ALTER TABLE table
[ADD <columnName> <data_type> [constraint_name]]
[DROP <constraint_name>]
[DROP column <columnName>]
[MODIFY <columnName> <data_type>];
ALTER TABLE TEmployees ADD EBirthday Date;
ALTER TABLE TEmployees MODIFY EdepId varchar2(8);
ALTER TABLE TEmployees DROP unique(EId);
ALTER TABLE TEmployees DROP column EBIRTHDAY;
Orcale 之 SQL 数据定义的更多相关文章
- SQL - 数据定义
SQL 的数据定义功能包括模式定义.表定义.视图和索引的定义: 操作对象 操作方式 创建 删除 修改 模式 create schema drop schema 表 create table d ...
- 数据库——SQL数据定义
数据定义 SQL的数据定义语句 操 作 对 象 操 作 方 式 创 建 删 除 修 改 表 CREATE TABLE DROP TABLE ALTER TABLE 视 图 CREATE ...
- orcale 之 SQL 数据查询
从数据库中检索行,并允许从一个或多个表中选择一个或多个行或列.虽然 SELECT 语句的完整语法较复杂,但是其主要的子句可归纳如下: SELECT select_list [ INTO new_tab ...
- SQL语言学习-数据定义语言
Sql语言至今已经有6个版本.SQL查询语言包括了所有对数据的操作命令,这些操作可分为四类:数据定义语言(DDL).数据操纵语言(DML).数据控制语言(DCL)和嵌入式SQL语言. 数据定义语言(D ...
- SQL DDL 数据定义语句
前言 DDL(Data Definition Language)语句:数据定义语句,这些语句定义了不同的数据段.数据库.表.列.索引等数据库对象.常用的语句关键字主要包括 create.drop.al ...
- sql 两大类 DDL数据定义语言 和DCL数据控制语言
SQL分为五大类: DDL:数据定义语言 DCL:数据控制语言 DML:数据的操纵语言 DTL:数据事务语言 DQL:数据查询语言. DDL (date definition lang ...
- ODPS SQL <for 数据定义语言 DDL>
数据定义语言:(DDL) 建表语句: CREATE TABLE [IF NOT EXISTS] table_name [(col_name data_type [COMMENT col_comment ...
- Oracle language types(语言种类) 表的相关操作 DDL数据定义语言
数据定义语言 Data Definition Language Statements(DDL)数据操纵语言 Data Manipulation Language(DML) Statements事务控制 ...
- SQL的定义与使用
一.SQL的定义 SQL(structured query language)即结构化查询语句,是关系数据库的标准语言. SQL的特点有: 1.综合统一 SQL集数据定义语言DDL.数据操作语言DML ...
随机推荐
- 关于super关键字与继承
super它只是一个限定词,当用super引用时,它也是引用当前对象本身,只是super只是限定了访问当前对象从父类那里继承得到成员变量或方法. import java.util.Date; publ ...
- [Erlang03]Erlang有哪些好用的静态分析工具?
1. dialyzer Dialyzer starts its analysis from either debug-compiled BEAM bytecode or from Erlang sou ...
- C# usb设备的自动退出
using System; using System.Collections.Generic; using System.Text; using System.Runtime.InteropServi ...
- javaScript prototype实例(正则) 自定义日期格式化方法
一个JS自定义日期格式化方法,包括了不少知识点,以下方法来自jQuery DataTable中文的官方参考 //return (new Date(data)).Format("yyyy-MM ...
- Entity Framework中的连接管理
EF框架对数据库的连接提供了一系列的默认行为,通常情况下不需要我们太多的关注.但是,这种封装,降低了灵活性,有时我们需要对数据库连接加以控制. EF提供了两种方案控制数据库连接: 传递到Context ...
- SystemID
A:BJQUANYONG-B:CCC332322987612323008002DDD A:JHDUJIA-B:CCC1365323754641263423809708001DDD A:GUANGZHO ...
- Filter 设计模式编码实践
原文地址: haifeiWu和他朋友们的博客 博客地址:www.hchstudio.cn 欢迎转载,转载请注明作者及出处,谢谢! 最近项目中遇到各种输出数据监控,数据校验等逻辑,一个个实现很是麻烦.项 ...
- leetcode 16. 3Sum Closest JAVA
题目: 给定一个包括n个整数的数组nums和一个目标值target.找到nums中的三个整数,使得他们之和与target最为接近.返回三个整数之和,假定每组输入只存在唯一答案 解题思路: 将nums数 ...
- OCP 12c最新考试题库及答案(071-2)
2019-02-12 16:23:54 2.(4-7) choose the best answer:You need to display the first names of all cust ...
- js 平均分割
let alllist=res.data; var result = []; for (var i = 0; i < alllist.length; i += 3) { result.push( ...