创建、维护表与约束

数据类型

  • 字符型
  • char自动补齐空值(定长字符型)
  • varchar2不自动补齐空置(变长字符型)
  • 数字型
  • number(p,s)p为总长度,s为小数点后保留位数
  • 日期型
  • date年月日时分秒
  • timestamp
  • 图片类型
  • blob

default定义默认值(如果不插入值则为默认值)

创建表

create table class
(name varchar2(20),
class number(20)
classno number(20))

修改表

  • alter table emp
    add(添加列)/modify(修改列)/drop(删除列)
  • 修改列名
alter table emp 
rename column mgr to managerno 

删除表

drop table emp

重命名表

rename emp to employee

截断表

truncate table emp
  • 截断表是删除表中所有数据,使用rollback不可以回滚

数据字典

  • oracle数据库里的表(sys用户中)
  • 查询数据字典
select table_name
from user_tables
  • 查看数据字典结构
desc user_tables

约束

  • constraint(列级、表级)
create table class(
name varchar(20) not null/unique)
  • 约束命名写在constraint后

  • 主键数据唯一,并且不能为空值

create table class(
id number constraint class_id_pk primary key,
 name varchar(20) 
 )
  • 外键必须是其他表里的主键或者唯一键
create table student(
id number,
name varchar2(20),
class_id number,
constraint student_classid_fk foreign key(class_id) references class(id)
on delete cascade
)
  • on delete cascade级联删除:主键行删除,将所有引用该主键的外键信息删除
  • on delete set null:主键行删除,将所有引用该主键的外键信息变为null
  • check约束:确保列中的数据满足条件
create table emp(
sal number(8,2) constraint emp_sal_min check (sal>0)
)
  • 追加约束
alter table emp 
add constraint emp_sal_ch check (sal>0)
  • 删除约束
alter table emp 
drop primary key|unique(column)|constraint emp_sal_ch
  • 删除该约束和与其相关的所有约束
alter table dept 
drop primary key emp_sal_ch cascade
  • 启用和禁用约束
alter table emp 
disable constraint emp_sal_ch
alter table emp 
enable constraint emp_sal_ch
  • 相关数据字典
select *
from user_constraints|user_cons_columns

练习2 通过子查询的方式创建一个表dept10,该表保存10号部门的员工数据。

create table dept10 as (select * from emp where deptno=10)

练习3.1 在员工表中添加一个性别列,列名为gender,类型为char(2),默认值为“男”。

alter table emp 
add(gender char(2) default '男')

3.2 修改员工表中性别列的数据类型为char(4)。

alter table emp 
modify(gender char(4))

3.3 修改员工表中性别列的默认值为“女”。

alter table emp 
modify(gender default '女')

3.4 删除员工表中的性别列。

alter table emp 
drop (gender)

课后作业2.创建表date_test,包含列d,类型为date型。试向date_test表中插入两条记录,一条当前系统日期记录,一条记录为“1998-08-18”。

create table date_test 
(d date );
insert into date_test values (sysdate);
insert into date_test values ('1998-08-18')
  1. 创建与dept表相同表结构的表dtest,将dept表中部门编号在40之前的信息插入该表。
create table dtest as (select * from dept where 1=0)
insert into  dtest (select * from dept where deptno<40)
  1. 创建与emp表结构相同的表empl,并将其部门编号为前30号的员工信息复制到empl表。
create table empl as(select * from emp where 1=0)
insert into empl (select * from emp where deptno<=30)
  1. 试为学生表student增加一列学生性别gender,默认值“女”。
alter table student add (gender varchar2(6) default '女')

6.试修改学生姓名列数据类型为定长字符型10位。

alter table student modify(XM char(10))

约束练习题

练习1.1 学校有一个选课系统,其中包括如下关系模式:

(系编号:主键,
系名称:唯一键,
系主任:非空约束,
系所在校区:取值范围只能在南湖校区和浑南校区)
班级
(班级编号:主键,
班级名称:唯一键,
所属系:外键)

create table chooseclass 
(xno number(10) constraint chooseclass_xno_pk primary key,
xname varchar2(20) constraint chooseclass_xname_uk unique,
xleader varchar2(20) constraint chooseclass_xleader_nn not null,
xschool varchar2(30) constraint chooseclass_xschool_ch check (xschool in ('南湖校区','浑南校区'))
);

create table class2
(cno number(10) constraint class2_cno_pk primary key,
cname varchar2(20) constraint class2_cname_uk unique,
cx number(10) constraint class2_cx_fk references chooseclass(xno)
)

1.2 创建学生表,包含如下属性:
学号 定长字符型 10位 主键
姓名 变长字符型 20位 非空
性别 定长字符型 2位 取值范围只能为男或女
出生日期 日期型
所在班级

create table student2
(id char(10) constraint student2_id_pk primary key,
name varchar2(20) constraint student2_name_nn not null,
sex char(2) constraint student2_sex_ch check (sex in ('男','女')),
birthday date,
cno number(10))

课后作业3. 创建copy_emp,要求格式同emp表完全一样。

create table copy_emp as
(select * from emp where 1=0)
  1. 创建copy_dept,要求格式同dept表完全一样。
create table copy_dept as 
(select * from dept where 1=0)
  1. 追加copy_dept表中主键deptno
alter table copy_dept
add constraint copydept_deptno_pk primary key (deptno)
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,098评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,213评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,960评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,519评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,512评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,533评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,914评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,574评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,804评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,563评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,644评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,350评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,933评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,908评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,146评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,847评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,361评论 2 342

推荐阅读更多精彩内容

  • 前面讲了SQL优化以及索引的使用、设计优化了,那么接下来就到表的设计与优化啦!!!真实地去设计优化单表结构以及讲述...
    JackFrost_fuzhu阅读 3,862评论 2 28
  • 目录 简介 在Android中存储数据有时会用到数据库,Android给我们提供了 一系列的API来操作数据库,非...
    慕涵盛华阅读 996评论 1 2
  • 小的时候似乎不懂得审美,周围的亲朋好友们偶尔说起某某某是个美女,我好像从来没有认同过,所以一直就不知道美人为何物。...
    张竹青yes阅读 638评论 1 5
  • 在2014年的最后一天,一鼓作气看了十来份年度总结,深受鼓舞。但就是写不出来自己的。我不着急,写不出来就不写。现在...
    scot0714阅读 421评论 0 1
  • 受湘潭一位妈妈携一双子女跳楼事件的影响,最近看了太多的文章说,妈妈要积极乐观,三观要正,要给孩子好的榜样,引...
    L严小雅阅读 506评论 0 0