对比了一下,实验二和往年的题目一模一样,下面我需要做的主要是把代码写在下面,以及手动制造两个错误(实验报告需要用)
另外实验指导里面貌似可以直接提交sql语句,是不是这样子提交就完事了?
笔者的建议是,首先复制下面的代码在交作业的网站上面,实验指导里面提交相应的sql语句,然后在自己的sqlplus上面操作,下面的命令,注意先创建表格才能进行操作,记得截图,记得制造一些错误并截图
第二题有三个语句,在提交的时候,放一块儿提交就好
第四题需要修改代码,因为要把自己的学号啥的填上去(另外这个可能作业网站本身有一些限制,需要把五条语句之间的空行删除,才能成功保存)
sqlplus A加自己的学号@172.22.112.234/orcl
按下回车,就可以输入口令,这样子截屏的时候就不会显示自己的口令,比较好
先创建表格再输入后面的命令
create table COUNTRIES as select * from univ.COUNTRIES;
create table DEPT as select * from univ.DEPT;
create table EMP as select * from univ.EMP;
alter table countries add primary key(cid);
alter table dept add primary key(deptno);
alter table emp add primary key(empno);
alter table dept add constraint d1 foreign key(CID) references countries on delete cascade;
alter table emp add constraint e1 foreign key(deptno) references dept on delete cascade;
工资介于5000到100000之间,约束名:chk_emp1
alter table emp add constraint e2 check(sal>=5000 and sal<=100000);
雇佣日期大于2002-02-02,约束名:chk_emp2
alter table emp add constraint e3 check(hiredate>to_date('2002-02-02','yyyy-mm-dd'));
工作类型的取值只能是:clerk,salesman,analyst,manager,president,约束名:chk_emp3
alter table emp add constraint e4 check(job in ('clerk','salesman','analyst','manager','president'));
insert into dept(deptno,dname,cid,loc) values(50,'production','CN','湘潭市');

这个可能作业网站本身有一些限制,需要把五条语句之间的空行删除,才能成功保存
insert into emp(empno,ename,job,sal,hiredate,comm,deptno) values(9324,'张三','manager',10000,to_date('2022-05-01','yyyy-mm-dd'),0,50);
insert into emp(empno,ename,job,mgr,hiredate,sal,comm,deptno) values(9001,'唐僧','clerk',9324,to_date('2022-05-02 00:00:00','yyyy-mm-dd hh24:mi:ss'),34000,0,50);
insert into emp(empno,ename,job,mgr,hiredate,sal,comm,deptno) values(9002,'孙悟空','clerk',9324,to_date('2022-05-03 00:00:00','yyyy-mm-dd hh24:mi:ss'),50000,0,50);
insert into emp(empno,ename,job,mgr,hiredate,sal,comm,deptno) values(9003,'猪八戒','clerk',9324,to_date('2022-05-04 00:00:00','yyyy-mm-dd hh24:mi:ss'),20000,0,50);
insert into emp(empno,ename,job,mgr,hiredate,sal,comm,deptno) values(9004,'沙僧','clerk',9324,to_date('2022-05-06 00:00:00','yyyy-mm-dd hh24:mi:ss'),10000,0,50);
要求:用临时编号作为职工编号,工作类型为“clerk”,工资15000。
请写出相应的SQL语句并执行。( 提交SQL语句 )
insert into emp
select 临时编号,姓名,'clerk',9324,to_date('2022-05-10','yyyy-mm-dd'),15000,0,50
from 待聘人员
where 姓名 like '旷%';
说明:部门职工收入总和是职工工资与佣金的总和
update dept
set emps = (
select count(emp.empno)
from emp
where dept.deptno=emp.deptno);
update dept
set income = (
select sum(sal)+sum(coalesce(comm,0))
from emp
where dept.deptno=emp.deptno);
delete from emp where deptno=20;
delete from dept where deptno=20;
delete from emp where sal<15000;
update emp set sal = sal+5000;
首先,可以先把后面的几句代码复制过去
第二步,查询表格里面的名字有哪些,使用下面这条命令
select ename from emp;
第三步,删除名字是张三的那一行,注意是单引号,最后需要加分号
DELETE FROM EMP WHERE ENAME='张三';
第四步,检查表格,使用第二步的sql语句
另外一个错误我是创建了一个重复的表格,这个确实不是很容易出现错误,到这儿,这个实验就做完了