orcale将hiredate>1983-01-01且sal<3000的员工加200工资,sal>3000的加100,用一个SQL写。

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了orcale将hiredate>1983-01-01且sal<3000的员工加200工资,sal>3000的加100,用一个SQL写。相关的知识,希望对你有一定的参考价值。

是要写一个函数?怎么写,没学过orcale

参考技术A orcale将hiredate>1983-01-01且sal<3000的员工加200工资,sal>3000的加100,用一个SQL写。
练习1、请查询表DEPT中所有部门的情况。
select * from dept;

练习2、查询表DEPT中的部门号、部门名称两个字段的所有信息。
select deptno,dname from dept;

练习3、请从表EMP中查询10号部门工作的雇员姓名和工资。
select ename,sal from emp where deptno=10;

练习4、请从表EMP中查找工种是职员CLERK或经理MANAGER的雇员姓名、工资。
select ename,sal from emp where job='CLERK' or job='MANAGER';

练习5、请在EMP表中查找部门号在10-30之间的雇员的姓名、部门号、工资、工作。
select ename,deptno,sal,job from emp where deptno between 10 and 30;

练习6、请从表EMP中查找姓名以J开头所有雇员的姓名、工资、职位。
select ename,sal,job from emp where ename like 'J%';

练习7、请从表EMP中查找工资低于2000的雇员的姓名、工作、工资,并按工资降序排列。
select ename,job,sal from emp where sal<=2000 order by sal desc;

练习8、请从表中查询工作是CLERK的所有人的姓名、工资、部门号、部门名称以及部门地址的信息。
select ename,sal,emp.deptno,dname,loc from emp,dept where emp.deptno=dept.deptno and job=’CLERK’;

练习9、查询表EMP中所有的工资大于等于2000的雇员姓名和他的经理的名字。
select a.ename,b.ename from emp a,emp b where a.mgr=b.empno(+) and a.sal>=2000;

练习10、在表EMP中查询所有工资高于JONES的所有雇员姓名、工作和工资。
select ename,job,sal from emp where sal>(select sal from emp where ename=’JONES’);

练习11、列出没有对应部门表信息的所有雇员的姓名、工作以及部门号。
select ename,job,deptno from emp where deptno not in (select deptno from dept);

练习12、查找工资在1000~3000之间的雇员所在部门的所有人员信息
select * from emp where deptno in (select distinct deptno from emp where sal between 1000 and 3000);

练习13、雇员中谁的工资最高。
select ename from emp where sal=(select max(sal) from emp);
select ename from (select * from emp order by sal desc) where rownum<=1;

*练习14、雇员中谁的工资第二高(考虑并列第一的情况,如何处理)。
select ename,sal from (select ename ,sal from emp where sal<(select max(sal) from emp) order by sal desc) where rownum<=1;
实验二
1. 查询所有雇员的姓名、SAL与COMM之和。
select ename,sal+nvl(comm,0) “sal-and-comm” from emp;

2. 查询所有81年7月1日以前来的员工姓名、工资、所属部门的名字
select ename,sal,dname from emp,dept where emp.deptno=dept.deptno and hiredate<=to_date(‘1981-07-01’,’yyyy-mm-dd’);

3. 查询各部门中81年1月1日以后来的员工数
select deptno,count(*) from emp where hiredate>=to_date(‘1981-01-01’,’yyyy-mm-dd’) group by deptno;

4. 查询所有在CHICAGO工作的经理MANAGER和销售员SALESMAN的姓名、工资
select ename,sal from emp where (job=’MANAGER’ or job=’SALES’) and deptno in (select deptno from dept where loc=’CHICAGO’);

5. 查询列出来公司就职时间超过24年的员工名单
select ename from emp where hiredate<=add_months(sysdate,-288);

6. 查询于81年来公司所有员工的总收入(SAL和COMM)
select sum(sal+nvl(comm,0)) from emp where to_char(hiredate,’yyyy’)=’1981’;

7. 查询显示每个雇员加入公司的准确时间,按××××年××月××日 时分秒显示。
select ename,to_char(hiredate,'yyyy-mm-dd hh24:mi:ss') from emp;

8. 查询公司中按年份月份统计各地的录用职工数量
select to_char(hiredate,'yyyy-mm'),loc,count(*) from emp,dept
where emp.deptno=dept.deptno group by to_char(hiredate,'yyyy-mm'),loc;

9. 查询列出各部门的部门名和部门经理名字
select dname,ename from emp,dept where emp.deptno=dept.deptno and job=’MANAGER’;

10. 查询部门平均工资最高的部门名称和最低的部门名称
select dname from dept where deptno=(select deptno from (select deptno from emp group by deptno order by avg(sal) ) where rownum<=1)
union all select dname from dept where deptno=(select deptno from (select deptno from emp group by deptno order by avg(sal) desc ) where rownum<=1);

11. *查询与雇员号为7521员工的最接近的在其后进入公司的员工姓名
select ename from (select ename from
(select ename from emp where hiredate>(select hiredate from emp where empno=7521) order by hiredate ) where rownum<=1)

orcale数据库学习---Orcale创建用户和表空间的方法

win+R进入“运行”,键入“cmd”回车,打开命令提示符窗口:

C:\Users\asministration>sqlplus --->(回车)

SQL*Plus:
Release 11.2.0.1.0 Production on 星期五 6月 22 19:46:17 2018
Copyright (c) 1982, 2010, Oracle. All rights reserved.

请输入用户名: *****(安装oracle时候的用户名)--->(回车)
输入口令:****(安装oracle时候的密码)--->(回车)

连接到:
Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - 64bit Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options

 

//=====创建表空间
//TABLESPACE_NAME:表空间的名字
//D:\SPACE_DIR:表空间的路径
SQL>create tablespace TABLESPACE_NAME datafile ‘D:\SPACE_DIR‘ size 2048M extent management local segment space management auto;

 

//=====创建用户
SQL>create user USER_NAME identified by "password";
用户已创建
//=====给用户授权
SQL>grant create session to USER_NAME;
授权成功。
SQL>grant create table to USER_NAME;
授权成功。
SQL>grant create tablespace to USER_NAME;
授权成功。
SQL>grant create view to USER_NAME;
授权成功。
SQL>grant connect,resource to USER_NAME;
授权成功
SQL>grant dba TO USER_NAME;

 

//将刚创建的用户分配表空间
SQL>alter user USER_NAME default tablespace TABLESPACE_NAME;
用户已更改。

//====查看是否自增
SQL>SELECT FILE_NAME,TABLESPACE_NAME,AUTOEXTENSIBLE FROM DBA_DATA_FILES;
//若最后一项结果是no(刚创建的表空间),需要修改自增
SQL>ALTER DATABASE DATAFILE ‘D:\SPACE_DIR‘ AUTOEXTEND ON NEXT 50M;
数据库已更改

 

 

=============================================================

进入cmd下面:>>>
imp USER_NAME/USER_PASSWORD file=D:\2018730sams.dmp(dmp文件的路径位置) full=y ignore=y
USER_NAME:要导入的表空间的用户名
USER_PASSWORD:要导入的表空间用户对应的密码

 

以上是关于orcale将hiredate>1983-01-01且sal<3000的员工加200工资,sal>3000的加100,用一个SQL写。的主要内容,如果未能解决你的问题,请参考以下文章

Orcale日期函数to_date(),to_char()

Orcal学习

11.07 存取“未来”行

orcale数据库学习---Orcale创建用户和表空间的方法

Orcal学习----Orcal用户关系

orcale 11g安装,创建表空间,用户,授权用户