表结构

SQL> desc emp
Name Type Nullable Default Comments
-------- ------------ -------- ------- --------
EMPNO NUMBER(4)
ENAME VARCHAR2(10) Y 员工姓名
JOB VARCHAR2(9) Y
MGR NUMBER(4) Y
HIREDATE DATE Y
SAL NUMBER(7,2) Y
COMM NUMBER(7,2) Y
DEPTNO NUMBER(2) Y

查询语句

--查询EMP表显示所有雇员名及其全年收入(月收入=工资+补助),处理NULL行,
--并指定列别名为"年收入"。(NVL(comm,0) comm取空值时用0替代)

select ename,12*(sal+nvl(comm,0)) 年收入 from emp;

--)查询EMP表显示工资超过2850的雇员姓名和工资
select ename,sal from emp where sal > 2850;

--查询EMP表显示工资不在1500~2850之间的所有雇员及工资
select ename,sal from emp where sal not between 1500 and 2850;

--查询EMP表显示代码为7566的雇员姓名及所在部门代码
select ename,deptno from emp where mgr=7566;

--查询EMP表显示部门10和30中工资超过1500的雇员名及工资

select ename,sal,deptno from emp where deptno in(10,30) and sal > 1500;
select ename,sal,deptno from emp where (deptno=10 or deptno=30) and sal>1500;

--查询EMP表显示第2个字符为"A"的所有雇员名其工资。
select ename,sal from emp where ename like '_A%';

select * from emp;

insert into emp(empno,ename,sal,deptno) values(8888,'zhang%san',8888,30);

select ename from emp where ename like '%x%%' escape('x');

--查询EMP表显示补助非空的所有雇员名及其补助。
select ename,comm from emp where comm is not null;

--查询EMP表显示所有雇员名、工资、雇佣日期,并以雇员名的升序进行排序。
select ename,sal,hiredate from emp order by ename asc;

--查询EMP表显示在1981年2月1日到1981年5月1日之间雇佣的雇员名、岗位及雇佣日期,并
--以雇佣日期进行排序。
select ename, job, hiredate
from emp
where hiredate between to_date('1981-2-1', 'yyyy-mm-dd') and
to_date('1981-5-1', 'yyyy-mm-dd')
order by hiredate desc;

--查询EMP表显示获得补助的所有雇员名、工资及补助,并以工资升序和补助降序排序
select ename,sal,comm from emp where comm is not null order by sal asc,comm desc;

--查询82年员工
select ename, hiredate
from emp
where hiredate between to_date('1982-1-1', 'yy-mm-dd') and
to_date('1982-12-31', 'yy-mm-dd');

--查询32年工龄的人员
select ename,hiredate,Months_between(sysdate,hiredate)/12 from emp where Months_between(sysdate,hiredate)/12 between 31 and 32;

--显示员工雇佣期 6 个月后下一个星期一的日期
select ename,hiredate,next_day(add_months(hiredate,6),'星期一') from emp;

--找没有上级的员工,把mgr的字段信息输出为 "boss"
select mgr,nvl(to_char(mgr),'boss') from emp;

--为所有人长工资,标准是:10部门长10%;20部门长15%;30
--部门长20%其他部门长18%
select ename,
sal,
deptno,
case
when deptno = 10 then
(sal * 0.1 + sal)
when deptno = 20 then
(sal * 0.15 + sal)
when deptno = 30 then
(sal * 0.2 + sal)
else
(sal * 0.18 + sal)
end
from emp;

--查询10号部门中编号最新入职的员工,工龄最长的员工的个人信息。
select *from emp where hiredate in
((select max(hiredate)from emp where deptno = 10),
(select min(hiredate) from emp where deptno = 10
));

select * from emp where deptno =10;

--从“software”找到‘f’的位置,用‘*’左右填充到15位,去除其中的‘a’
select instr('software','f') from dual;
select lpad('software',15,'*') from dual;
select rpad('software',15,'*') from dual;
select replace('software','a') from dual;

--查询员工的奖金,如果奖金不为NULL显示‘有奖金’,为null则显示无奖金
select ename,comm,decode(comm,null,'无奖金','有奖金') from emp;

--写一个查询显示当前日期,列标题显示为Date。再显示六个月后的日期,下一个
--星期 日的日期,该月最后一天的日期。
select sysdate "Date",add_Months(sysdate,6),next_day(sysdate,'星期日'),last_day(sysdate) from dual;

-- 查询EMP表按管理者编号升序排列,如果管理者编号为空则把为空的在最前显示
select * from emp order by mgr asc nulls first;

--求部门平均薪水
select deptno,avg(sal) from emp group by deptno;

--找出每个部门的平均、最小、最大薪水
select deptno,avg(sal),max(sal),min(sal) from emp group by deptno;
select * from emp;

--按部门求出工资大于1300人员的 部门编号、平均工资、最小佣金、最大佣金,并
--且最大佣金大于100
select deptno,avg(sal),min(comm),max(comm) from emp where sal>1300 group by deptno having max(nvl(comm,0))>100;

select e.deptno,avg(e.sal),min(e.comm),max(e.comm) from emp e where e.sal>1300 group by e.deptno having max(nvl(e.comm,0))>100;

--查询出雇员名,雇员所在部门名称, 工资等级。
select * from emp e ,dept d where e.deptno = d.deptno;
select * from salgrade;
select e.ename, d.dname, sg.grade
from emp e, dept d, salgrade sg
where e.deptno = d.deptno
and e.sal between sg.losal and sg.hisal;

sql语句基本查询操作的更多相关文章

  1. sql语句之查询操作

    语法顺序: select distinct 字段1,字段2,字段3 from 库.表 where 条件 group by 分组条件 having 过滤 # 执行顺序的话,到这步会返回运行select语 ...

  2. 在Hibernate中使用HibernateTemplate来进行包含sql语句的查询

    /**     * 使用sql语句进行查询操作     * @param sql     * @return     */    public List queryWithSql(final Stri ...

  3. Statement执行DQL语句(查询操作)

    import java.sql.Connection; import java.sql.ResultSet; import java.sql.Statement; import org.junit.T ...

  4. [Beego模型] 四、使用SQL语句进行查询

    [Beego模型] 一.ORM 使用方法 [Beego模型] 二.CRUD 操作 [Beego模型] 三.高级查询 [Beego模型] 四.使用SQL语句进行查询 [Beego模型] 五.构造查询 [ ...

  5. SQL语句关联查询

    一:连接类型: 关联查询:只有存在关联的表才能关联查询,完全独立的表之间无法关联 1.关联的类型:自关联,左关联,右关联,全关联(full join)两张表都是主表 2.关联的表:两张以上,以一张(或 ...

  6. SQL语句之表操作

    SQL语句系列 1.SQL语句之行操作 2.SQL语句之表操作 3.SQL语句之数据库操作 4.SQL语句之用户管理 写在前面 在上一篇博文里面我整理了“行”级别的操作,分别是“增(insert).删 ...

  7. SQL语句之行操作

    SQL语句系列 1.SQL语句之行操作 2.SQL语句之表操作 3.SQL语句之数据库操作 4.SQL语句之用户管理 关系型数据库的存储形式 在关系型数据库中,数据都是以类似于Excel表格的形式存储 ...

  8. MySQL的EXPLAIN命令用于SQL语句的查询执行计划

    MySQL的EXPLAIN命令用于SQL语句的查询执行计划(QEP).这条命令的输出结果能够让我们了解MySQL 优化器是如何执行SQL 语句的.这条命令并没有提供任何调整建议,但它能够提供重要的信息 ...

  9. mysql 常用 sql 语句 - 快速查询

    Mysql 常用 sql 语句 - 快速查询 1.mysql 基础 1.1 mysql 交互         1.1.1 mysql 连接             mysql.exe -hPup    ...

随机推荐

  1. PAT乙级考前总结(二)

    简单模拟 1002 写出这个数 (20 分) 1006 换个格式输出整数 (15 分) 又是数数 1016 部分A+B (15 分) 相当于找数字 1018 锤子剪刀布 (20 分) 题目略 此处用了 ...

  2. 如何使用python在保留原excel格式的前提下插入/修改数据

    一.需求分析: 统计的报表中需要每日查询当天数据并追加到原有的excel后面. 因为原始excel格式已经设定好,如果使用xlwt,仅仅指定设定我们要插入的单元格的格式,原始数据的格式会被初始化. 所 ...

  3. C# DataView数据处理的几种方法

    1.找到刚删除的所有列 DataView dv = dt.DefaultView; dv.Delete(); dv.Delete(); //找出所有刚删除掉的行 1.5 dv.RowStateFilt ...

  4. ImportError: dynamic module does not define module export function (PyInit__sqlite3)

    使用python3.6 中的django-admin创建项目的时候报错 ImportError: dynamic module does not define module export functi ...

  5. Java面试问题汇总

    转一些面试经验 刚看到下面这份面试清单,从个人的开发面试经历看,里面总结的大部分内容还是很不错的.年后想跳槽的朋友可以选取里面的问题准备一下. GitHub上的面试总结帖 Interview-Note ...

  6. httpd基于域名虚拟主机配置

    什么是虚拟主机 在一个Apache服务器上可以配置多个虚拟主机,实现一个服务器提供多站点服务,其实就是访问同一个服务器上的不同目录. httpd支持多种方式的虚拟主机的配置,主要有以下种: 基于IP ...

  7. Open Source 开发工具集

    Open Source 开发工具集 转自:http://www.linuxforum.net原作者:gogoliu(Pooh-Bah) 编辑器: vi:老牌编辑器,在各个unix和unix-like平 ...

  8. Linux简易APR内存池学习笔记(带源码和实例)

    先给个内存池的实现代码,里面带有个应用小例子和画的流程图,方便了解运行原理,代码 GCC 编译可用.可以自己上网下APR源码,参考代码下载链接: http://pan.baidu.com/s/1hq6 ...

  9. MySQL面试题中:主从同步部署介绍

    主从同步部署1.两台相同版本的mysql数据库,一台做主库,一台从库 主库开启binlog 在配置文件中的[mysqld]模块中添加log-bin=mysql-bin和server-id=1,一定要保 ...

  10. spring @Configuration的使用

    参考博客:https://www.cnblogs.com/duanxz/p/7493276.html spring中的@Scope注解  https://www.cnblogs.com/loneclo ...