oracle更新学生表年龄,2018.5.19 Oracle数据操作和管理表的综合练习

--作业一、使用自己的用户登录,完成如下操作,并且创建5条测试数据

-- 创建学生表(stu),字段如下:

-- 学号(stuID)

-- 姓名(stuName)

-- 性别(stuSex)

-- 入学时间(stuDate)

create table stu (

stuID number(12),

stuName varchar(5),

stuSex varchar(2) check(stuSex in(‘男‘,‘女‘)),

stuDate date

);

--二、请创建一个表,表名为phone,表结构如下

电话号码(PHONENUM VARCHAR2(8))

电话费 (PAY number(8,2))

号码等级(NUMLEVEL VARCHAR2(4))

费用日期(PAYDATE varchar2(12)

create table phone(

phonenum varchar2(8),

pay number(8,2),

numlevel varchar2(4),

paydate varchar2(12)

);

1、插入以下两条数据.

123456, 600, pt04, 20051220

888888, 900, pt05, 20051019

insert into phone (phonenum,pay,numlevel,paydate) values(123456,600,‘pt04‘,20051220);

insert into phone (phonenum,pay,numlevel,paydate) values(888888,900,‘pt05‘,20051019);

2、创建一个备份表结构名为phone_bak, 将phone中的数据插入phone_bak中.

create table phone_bak as select * from phone;

3、将电话号码为123456的电话费改为1000,执行回滚操作

update phone set paydate=1000 where phonenum=123456;

rollback;

4、在phone表中,如果PHONENUM字段中的数据为‘123456’,则返回‘Y’否则返回‘N’

select decode(phonenum,‘123456‘,‘y‘,‘n‘) from phone;

5、将phone表中的电话号码为123456的记录的费用日期(PAYDATE)字段的日期转变成YYYY/MM/DD格式

select to_date(paydate,‘yyyy/mm/dd‘) from phone where phonenum=123456;

update phone set paydate=to_date(paydate,‘yyyy/mm/dd‘) where phonenum=123456;

6、将电话号码为888888的号码等级改为pt04并提交

update phone set numlevel=‘pt04‘ where phonenum=888888;

commit;

--三、创建满足下面条件的三个数据库表

--表名:Card

作用:存储上网卡信息

-------------------------------------------------------------------

列名 数据类型 长度 是否为空 字段说明

ID varchar 10 否 主键,不允许有相同值

PassWord varchar 50 否 密码

Balance int 4 是 卡上余额

UserName varchar 50 是 持卡人姓名

-------------------------------------------------------------------

create table Card (

ID varchar(10) primary key,

PassWord varchar(50) not null,

Balance number(4),

UserName varchar(50)

);

--添加注释内容

comment on column Card.password is ‘密码‘;

comment on column Card.Balance is ‘卡上余额‘;

--表名:Computer

作用:存储计算机及状态信息

-------------------------------------------------------------------

列名 数据类型 长度 是否为空 字段说明

ID varchar 10 否 主键,不允许有相同值

CardID varchar 1 否 是否正在使用

ComputerID varchar 100 是 备注和说明信息

-------------------------------------------------------------------

create table Computer (

ID varchar(10) primary key,

CardID varchar(1) not null,

ComputerID varchar(100) not null

);

表名:Record

作用:存储每次上机的信息

-------------------------------------------------------------------

列名 数据类型 长度 是否为空 字段说明

ID numeric 8 否 主键,不允许有相同值

CardID varchar 10 否 外键,引用Card表的ID字段

ComputerID varchar 10 否 外键,引用Computer表的ID字段

BeginTime data 4 是 开始上机时间

EndTime data 4 是 下机时间

Fee data 9 是 本次上机费用

-------------------------------------------------------------------

create table Record (

ID number(8) not null,

CardID varchar(10) not null,

ComputerID varchar(10) not null,

BeginTime date,

EndTime date,

Fee date

);

foreign KEY(CardID) REFERences Card(ID)

--查看约束

select constraint_name,table_name from user_constraints where table_name =upper(‘computer‘);

--注释内容

comment on column Record.Fee is ‘本次上机费用‘;

comment on column Record.BeginTime is ‘开始上机时间‘;

comment on column Record.Fee is ‘本次上机费用‘;

comment on column Record.EndTime is ‘下机时间‘;

创建表之后,编写和实施约束,要求如下:

1、针对Record表的CardID、ComputerID字段分别与Card表、Computer表建立主外键关系(引用完整性约束)

alter table Record add constraint fk_CardID foreign key(CardID) references Computer(ID);

2、Card表中,卡上的余额不能超过1000

alter table Card add constraint ck_Balance check(balance<=1000);

3、Computer表中,OnUse只能是0或者1

alter table computer add (onUse number(2));

alter table computer add constraint ck_onUse check (onUse in(0,1));

4、Record表中,EndTime不能早于BeginTime (错的)

alter table computer add constraint ck_Time check(to_date(EndTime,‘yyyy-mm-dd hh24:mi:ss‘)>to_date(BeginTime,‘yyyy-mm-dd hh24:mi:ss‘));

--作业02修改字段

1、为stu表添加年龄字段(stuAge),类型为(number(8)),并且统一赋值为 30.

alter table stu add (stuAge number(8) default(30));

2、修改stuName字段为(varchar2(20))

alter table stu modify(stuName varchar(20));

3、删除studate字段

alter table stu drop studate;

--作业04-1 添加约束

创建班级表(clsses),字段包含:

【班级编号(cid)、班级名称(cname)】

create table classes(

cid number(8),

cname varchar2(20)

);

需求如下:

1、为“班级编号添”加主键约束

alter table classes add constraint pk_cid primary key(cid);

2、为“班级名称”添加非空约束

alter table classes modify (cname not null);

3、插入3条测试数据

insert into classes values(1001,‘蓝桥1班‘);

insert into classes values(1002,‘蓝桥2班‘);

insert into classes values(1003,‘蓝桥3班‘);

创建学生表(stus),字段包含:

【学号(stuID)、姓名(stuName)、性别(stuSex)、年龄(stuAge)、入学时间(stuDate),班级编号(cid)】

create table stus(

stuID number(8), --学号

stuName varchar2(20), --姓名

stuSex char(2), --性别

stuAge number(8), --年龄

stuDate Date, --入学时间

cid number(8) --班级编号

);

需求如下:

1、为stuID添加主键约束

alter table stus add constraint py_stuID primary key(stuID);

2、为stuName添加非空约束

alter table stus modify (stuName not null);

3、为stuSex添加默认值

alter table stus modify (stuSex char(4));--修改长度

alter table stus modify (stuSex default ‘男‘);

4、为stuAge添加检查约束 0-100

alter table stus add constraints ck_stuAge check(stuAge>=0 and stuAge<=100);

5、为stuDate添加唯一性约束

alter table stus add constraint un_stuDate unique(stuDate);

6、为cid添加外键约束

alter table stus add constraint fk_cid foreign key (cid) references classes (cid) on delete cascade; --添加外键

select constraint_name,table_name from user_constraints where table_name =upper(‘stus‘);--查看约束

alter table stus drop CONSTRAINT fk_cid; --删除外键约束

7、添加5条测试数据

insert into stus values(1801,‘Ben‘,‘男‘,21,to_date(‘2015/5/19‘,‘yyyy-mm-dd‘),1001);

insert into stus values(1800,‘BenQ‘,‘女‘,19,to_date(‘2017/2/29‘,‘yyyy-mm-dd‘),1003);

insert into stus values(1802,‘Chen‘,‘男‘,22,to_date(‘2018/6/22‘,‘yyyy-mm-dd‘),1002);

insert into stus values(1803,‘Legend‘,‘男‘,25,to_date(‘2014/8/19‘,‘yyyy-mm-dd‘),1003);

insert into stus values(1804,‘Wave‘,‘女‘,21,to_date(‘2016/5/19‘,‘yyyy-mm-dd‘),1002);

insert into stus values(1805,‘QQ‘,‘女‘,20,to_date(‘2016/7/21‘,‘yyyy-mm-dd‘),1003);

--04-2约束练习

1、创建表 emp1,字段如下

eno char(3),

ename char(6),

sex char(2),

age number(2),

dno char(3)

create table emp1(

eno char(3),

ename char(6),

sex char(2),

age number,

dno char(3)

);

2、并插入如下数据

1 ,TOM , 男 , 21 ,’001’

2 ,JERRY ,男 ,21 ,’002’

3 ,KATE , 女 ,21 ,’003’

4 ,MARY ,女 ,21 ,’004’

5 ,JACK , 男 ,21 ,’005’

insert into emp1 values(1,‘TOM‘,‘男‘,21,001);

insert into emp1 values(2,‘JERRY‘,‘男‘ ,21,‘002‘);

insert into emp1 values(3,‘KATE‘,‘女‘,21,003);

insert into emp1 values(4,‘MARY‘,‘女‘ ,21,‘004‘);

insert into emp1 values(5,‘JACK‘,‘男‘,21,‘005‘);

3、 在eno字段上创建主键约束

alter table emp1 add constraint pk_ eno primary key(eno);

4、 在ename字段上创建非空约束

alter table emp1 modify (ename not null);

5、 创建检查约束判断age在18到60岁之间的男性或者age在18到55岁之间的女性

alter table emp1 add constraint ck_age check ((sex=‘男‘) and (age between 18 and 60) or (sex=‘女‘ and age between 18 and 55));

insert into emp1 values (666,‘Legend‘,‘男‘,20,100);--测试数据

insert into emp1 values (66,‘Lily‘,‘女‘,120,100);

6、 在dno字段上创建唯一性约束

alter table emp1 add constraint un_dno unique(dno);

7、创建和emp1表字段相同的emp_bak表,将emp_bak表的eno字段与emp表的eno字段创建外键约束

create table emp_bak ad select * from emp1;

alter table emp1 add constraint fk_emo foreign key emp_bak(eno) references emp1(eno);

--作业04-3 添加约束

创建clsses表:

create table classes

(

cid number(8),

cname varchar2(20)

);

为cid添加主键约束

alter table classes add constraint pk_cid primary key(cid);

创建stus表:

create table stus(

stuID number(8), --学号

stuName varchar2(20), --姓名

stuSex char(2), --性别

stuAge number(8), --年龄

stuDate Date, --入学时间

cid number(8)

);

为stuID添加主键约束

alter table stus add constraint pk_stuID primary key(stuID);

为stuName添加非空约束

alter table stus modify (stuName not null);

为stuSex添加默认值

alter table stus modify (stuSex dafault ‘女‘);

为stuAge添加检查约束 0-100

alter table stus add constraint ck_stuAge check(stuAge between 0 and 100);

为stuDate添加唯一性约束

alter table stus add constraint un_stuDate unique (stuDate);

为cid添加外键约束

alter table stus add constraint fk_cid foreign key (cid) reference classes (cid);

原文:https://www.cnblogs.com/qichunlin/p/9059764.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值