- 1、本文档共7页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
oracle作业(答案)
方法一
1、从表1获取数据,格式化输出为表2。
drop user ben cascade;
create user ben identified by 12345;
grant dba to ben;
conn ben/12345;
show user ;
create table tableone
(
studname varchar2(16),
coursename varchar2(16),
cscore number(2) check(cscore =0 and cscore =100),
uscore number check(uscore in (1,3,5))
);
insert into tableone values(李白,摔跤,80,1);
insert into tableone values(李白,军事理论,60,5);
insert into tableone values(李白,数学,70,3);
insert into tableone values(杜甫,摔跤,95,1);
insert into tableone values(杜甫,军事理论,85,5);
insert into tableone values(杜甫,数学,75,3);
insert into tableone values(李清照,摔跤,45,1);
insert into tableone values(李清照,军事理论,55,5);
insert into tableone values(李清照,数学,50,3);
insert into tableone values(蔡琰,摔跤,25,1);
insert into tableone values(蔡琰,军事理论,15,5);
insert into tableone values(蔡琰,数学,10,3);
create or replace view tabletwo
as
select studname as 姓名,
max(decode(coursename,摔跤, cscore)) as 摔跤,
max(decode(coursename,军事理论, cscore)) as 军事理论,
max(decode(coursename,数学, cscore)) as 数学,
sum(uscore) as 总学分
from tableone group by studname;
set pagesize 15;
column studname format a18;
column coursename format a18;
select * from tableone;
select * from tabletwo;
2、从表2读取数据,格式化输出为表1。
drop table tableone;
drop view tabletwo;
create table tabletwo
(
姓名 varchar2(16),
摔跤 number(2),
军事理论 number(2),
数学 number(2),
总学分 number
);
insert into tabletwo values(李白,80,60,70,9);
insert into tabletwo values(杜甫,95,85,75,9);
insert into tabletwo values(李清照,45,55,50,9);
insert into tabletwo values(蔡琰,25,15,10,9);
create or replace view tableone
as
select distinct(姓名) as studname,
decode(user_tab_cols.column_name,摔跤, user_tab_cols.column_name,军事理论, user_tab_cols.column_name ,数学, user_tab_cols.column_name) as coursename,
decode(user_tab_cols.column_name,摔跤,摔跤,军事理论, 军事理论,数学, 数学) as cscore,
decode(user_tab_cols.column_name,摔跤,1,军事理论, 5,数学, 3) as uscore
from tabletwo, user_tab_cols order by studname;
set pagesize 20;
column studname format a26;
column coursename format a26;
select *
文档评论(0)