Oracle day05 建表_约束
CREATE TABLE [schema.] table (column datatype [DEFAULT expr], ... );
CREATE TABLE table [column(,column...)] AS subquery,
create table emp2 as select * from emp;
- alter table ... add ... : 增加新的列
alter table emp add address varchar()
- alter table ...drop ... : 删除原有的列
alter table emp drop column address
- alter table ...modify ... : 修改字段
alter table emp modify(job varchar())
- drop table : 在基本表不需要时,可以使用语句撤销。
drop table emp cascade constraints
- RENAME : 语句改变表名(视图),要求必须是表(视图)的所有者
RENAME old_name TO new_name
- not null 非空
- unique Key 唯一键
- primary key 主键
- foreign key 外键
- check 自定义检测约束
carete table parent(p1 number primary key); create table child (c1 number primary key ,c2 number references parent(p1));
create table child (c1 nnumber ,c2 number ,primary key(c2), foreign key(c2) references parent(p1));
create table test(id1 number ,id2 number ,primary key(id1,id2));
- 主键从功能上看相当于非空且唯一
- 一个表中只允许一个主键
- 主键是表中能够唯一确定一个行数据的字段
- 主键字段可以是单字段或者是多字段的组合
- Oracle 为主键创建对应的唯一性索引
- primary key(列)主键子句 在表的定义中加上
- primary key主键短语 在主属性的定义之后加上
create table t3( id number(), constraint t3_pk primary key(id) )
- 确保字段值不允许为空
- 只能在字段级定义
CREATE TABLE employees( employee_id number(), name varchar2() not null, salary number(,), hire_date date constraint emp_hire_date_nn not null )
- 唯一性约束条件确保所在的字段或者字段组合不出现重复值
- 唯一性约束条件的字段允许出现空值
- Oracle 将为唯一性约束条件创建对应的唯一性索引
create table employees( id number(), name varchar2() not null unique, email varchar2(), salary number(,), hire_date date not null, constraint emp_email_uk unique(email) );
create table emp3( id number() primary key , age number() check(age > and age <), salary number(,), sex char(), constraint salary_check check(salary>) )
- 实体完整性规则 这条规则要求关系中在组成主键的属性上不能有空值
- 参照完整性规则 这条规则要求“不引用不存在的实体”
- 用户定义的完整性规则 反应了某一具体的应用涉及的数据必须满足的语义要求
alter table tablename
增加
add constraint con_name unique(col)
删除
drop constraint com_name[cascade]
select constraint_name,constraint_type from user_constraints where table_name=upper('sxtstu05')
select constraint_name,constraint_type from user_constraints where owner ='SCOTT'
select constraint_name,column_name from user_cons_columns where table_name =upper('tablename')
Oracle day05 建表_约束的更多相关文章
- oracle基本建表语句
oracle基本建表语句 2010-09-20 10:37:33| 分类: 数据库 | 标签:数据库 oracle |字号 订阅 --创建用户create user han identifie ...
- PowerDesigner连接Oracle数据库建表序列号实现自动增长
原文:PowerDesigner连接Oracle数据库建表序列号实现自动增长 创建表就不说了.下面开始介绍设置自动增长列. 1 在表视图的列上创建.双击表视图,打开table properties — ...
- SQL Server— 存在检测、建库、 建表、约束、外键、级联删除
/******************************************************************************** *主题: SQL Server- 存 ...
- Oracle学习(三)SQL高级--表结构相关(建表、约束)
一.建表语句 CREATE DATABASE(创建数据库) --创建数据库 create database 数据库名字; CREATE TABLE(创建表) --创建表 CREATE TABLE 表名 ...
- oracle的建表语句
oracle数据库的建表语句,具体语法如下: CREATE TABLE tablename (column_name datatype [null,not null], column_name dat ...
- Oracle数据库建表+添加数据练习
SQL脚本: --建表 --student表+注释 create table student( sno ) not null, sname ) not null, ssex ) not null, s ...
- oracle 存储过程 建表插值等
建表.插值的procedure create or replace procedure CREATE_EMP is v_createsql ); v_insertsql ); begin v_crea ...
- oracle得到建表语句
第一种方法是使用工具,如:pl/sql developer,在[工具]--[导出用户对象]出现就可以得到建表脚本. 第二种方法是,sql语句. DBMS_METADATA.GET_DDL包可以得到数据 ...
- Oracle的关于建表,约束,查询等的练习
从建立一个简单表,到实现一些复杂查询的例子, DROP TABLE grade;DROP TABLE item;DROP TABLE sporter;CREATE TABLE sporter( spo ...
随机推荐
- 详解微信小程序开发(项目从零开始)
一.序 微信小程序,估计大家都不陌生,现在应用场景特别多.今天就系统的介绍一下小程序开发.注意,这里只从项目代码上做解析,不涉及小程序如何申请.打包.发布的东西.(这些跟着微信官方文档的流程走就好). ...
- ckeditor+ckfinder
官方地址:http://ckeditor.com/ 复制ckeditor和ckfinder的文件夹到项目根路径下 拷贝ckfinder的config.xml到WEB-INF下 <config&g ...
- Python课程学习总结
Python的介绍 Python是一种高级动态.完全面向对象的语言,函数.模块.数字.字符串都是对象,并且完全支持继承.重载.派生.多继承,有益于增强源代码的复用性. Python是一种计算机程序设计 ...
- js 格式化数字,格式化金额:
js 格式化数字,格式化金额: function number_format(number, decimals, dec_point, thousands_sep) { /* * 参数说明: * nu ...
- 中间人攻击——ARP欺骗的原理、实战及防御
1.1 什么是网关 首先来简单解释一下什么是网关,网关工作在OSI七层模型中的传输层或者应用层,用于高层协议的不同网络之间的连接,简单地说,网关就好比是一个房间通向另一个房间的一扇门. 1.2 A ...
- [Swift]LeetCode74. 搜索二维矩阵 | Search a 2D Matrix
Write an efficient algorithm that searches for a value in an m x n matrix. This matrix has the follo ...
- [Swift]LeetCode233. 数字1的个数 | Number of Digit One
Given an integer n, count the total number of digit 1 appearing in all non-negative integers less th ...
- 关于移动端开发,vedio标签层级高遮挡蒙版的解决方案
问题描述: 使用famework7框架搭建了一个界面,然后再界面中需要使用蒙版效果,在PC端,ios测试没有问题,在Andriod播放视屏再点击显示蒙版的效果师,视频会遮盖蒙版.修改定位,z-inde ...
- Python档案袋(线程 )
Python的进程和线程是使用的操作系统的原生线程和进程,其是去调用操作系统的相应接口实现 进程:之间不可直接共享数据,是资源的集合,进程必须有一个线程 线程:基于进程,之间可直接共享数据,可执行,只 ...
- Git漏洞允许任意代码执行(CVE-2018-17456)复现
Git漏洞允许任意代码执行(CVE-2018-17456) 国外安全研究员 joernchen 在 9 月 23 日向 git 官方报告了漏洞的相关细节.10月5日,Git项目披露了一个漏洞,编号为C ...