SQL/Oracle——第八章 数据表对象(作业六)

表是数据库中一种非常重要的数据对象,它是储存数据的主要手段和容器
分为行与列
列:一个属性,有名称,数据类型,大小
行:一条记录,描述一个实体
从E-R图(实体联系图)转化为数据库中的表

创建表
create table scott.students(//表名前加账户名可以创建其它账户的表
主键
studentID CHAR(6) PRIMARY KEY,
--constraint studentID_PK primary key(studentID) 带名字的
--alter table students add constraint studentID_PK primary key(studentID,name);可以搞两个
外键(子表orders的外键是sid)
--sid number references student(studentID) on delete cascade,级联删除
--alter table orders add constraint fk_order foreign key(sid) references student(studentID);
非空
stuno number(10) not null, --学号,数字类型(10位),
--alter table students modify stuno null;
唯一键
name VARCHAR2(20) constraint uk_name UNIQUE,
--alter table course add constraint uk_name  unique(name);
约束
sex char(2) constraint ch_sex default '男' CHECK(sex='男' or sex='女'),--只能输入规定值,默认值为男
//ALTER TABLE student  ADD CONSTRAINT ch_sex CHECK(sex IN('男','女')); 
age number(3) CONSTRAINT ch_age CHECK (age>=18 AND age<=30),--使得年龄的值在18~30岁之间。

regdate date default sysdate--建档日期,日期默认格式,当前系统日期
);
2.增加、修改、删除字段
--给student表增加一个memo字段,类型为varchar2(200)
alter table student add(memo varchar2(200));
--将memo字段的类型修改为varchar2(300)
alter table student modify memo varchar2(300);
--删除memo字段
alter table student drop memo;
1alter table s1 modify departno varchar2(4); --修改字段长度:将departno字段的数据类型改为varchar2(4)
2alter table s1 rename column age to sex;   --将age字段改为sex字段
3) alter table s1 modify age char(2); --将age字段的数据类型改为char(2)

--插入数据
insert into custemer values(1,'张三','吉林长春','123123');
--查看表的结构
describe students; 
--复制表
create table students_2 as select * from stdents;
--查找约束名:
select constraint_name,table_name,column_name from user_cons_columns where table_name='B1';
--删除约束:
alter table students drop constraint studentID_PK;

对表定义约束: 实现一些基本的应用逻辑; 对表中数据的有效性和完整性的维护。

创建外键全过程
外键约束

作业六
--创建学生表student
create table student(
sno char(10), --学号,数字类型(10位)
constraint sno_PK primary key(sno),--设置主键约束sno_PK,不需要设置not null
sname varchar2(8),--姓名,字符串,会自动变长变短(8位),char是固定长度
sex char(2),--性别,两位
constraint ch_sex default '男' check(sex="男" or sex="女"),
birthday date default,--生日,整型
sdept char(20) not null,--系别,非空
);

--创建课程表course
create table course(
cno char(10),--课程号
constraint cno_PK primary key(cno),--设置主键约束cno_PK
cname char(30) unique,
ccredit number(3)
);

--创建学生成绩表score
create table score(
sno char(10) primary key(sno),
score_sno char(10) references student(sno), -- 设置外键约束
cno char(10) primary key(cno),
score_cno char(10) references course(cno), -- 设置外键约束
grade number(3)constraint grade_CK check (grage>=0 and grade<=100)
);

2.增加、修改、删除字段
--给student表增加一个memo字段,类型为varchar2(200)
alter table student add(memo varchar2(200));
--将memo字段的类型修改为varchar2(300)
alter table student modify memo varchar2(300);
--删除memo字段
alter table student drop memo;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值