2018.5.9 Oracle数据库查询命令
0.查询所有数据(最简单,但是时间很久)
select * from emp;
Result:
EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
----- ---------- --------- ----- ----------- --------- --------- ------
7369 SMITH CLERK 7902 1980/12/17 800.00 20
7499 ALLEN SALESMAN 7698 1981/2/20 1600.00 300.00 30
7521 WARD SALESMAN 7698 1981/2/22 1250.00 500.00 30
7566 JONES MANAGER 7839 1981/4/2 2975.00 20
7654 MARTIN SALESMAN 7698 1981/9/28 1250.00 1400.00 30
7698 BLAKE MANAGER 7839 1981/5/1 2850.00 30
7782 CLARK MANAGER 7839 1981/6/9 2450.00 10
7788 SCOTT ANALYST 7566 1987/4/19 3000.00 20
7839 KING PRESIDENT 1981/11/17 5000.00 10
7844 TURNER SALESMAN 7698 1981/9/8 1500.00 0.00 30
7876 ADAMS CLERK 7788 1987/5/23 1100.00 20
7900 JAMES CLERK 7698 1981/12/3 950.00 30
7902 FORD ANALYST 7566 1981/12/3 3000.00 20
7934 MILLER CLERK 7782 1982/1/23 1300.00 10
1.查询系统时间 (这个表是用户的数据库里面没有建立所以要用虚表 dual )
select sysdate from dual;
Result:
SYSDATE
-----------
2018/5/9 20
2.去除重复的查询数据
select distinct(deptno) from emp;
Result:
DEPTNO
------
30
20
10
3.查询数据库起别名显示
select ename "姓名" ,sal*12 "年薪" from emp;
Result
姓名 年薪
---------- ----------
SMITH 9600
ALLEN 19200
WARD 15000
JONES 35700
MARTIN 15000
BLAKE 34200
CLARK 29400
SCOTT 36000
KING 60000
TURNER 18000
ADAMS 13200
JAMES 11400
FORD 36000
MILLER 15600
4.进行运算
select 3*4+1*2 from dual;
Result:
3*4+1*2
----------
14
5.NVL函数可以处理有空值的字段
6.查询部门编号为10的员工信息 (需要加上where条件过滤)
select * from emp where DEPTNO=10;
Result:
EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
----- ---------- --------- ----- ----------- --------- --------- ------
7782 CLARK MANAGER 7839 1981/6/9 2450.00 10
7839 KING PRESIDENT 1981/11/17 5000.00 10
7934 MILLER CLERK 7782 1982/1/23 1300.00 10
7.查询编号不为10的部门的员工信息
select ename,sal,deptno from emp where deptno <>10;
Result
ENAME SAL DEPTNO
---------- --------- ------
SMITH 800.00 20
ALLEN 1600.00 30
WARD 1250.00 30
JONES 2975.00 20
MARTIN 1250.00 30
BLAKE 2850.00 30
SCOTT 3000.00 20
TURNER 1500.00 30
ADAMS 1100.00 20
JAMES 950.00 30
FORD 3000.00 20
8.范围查询显示结果
select ename,sal from emp where sal between 800 and 1500;
Result:
ENAME SAL
---------- ---------
SMITH 800.00
WARD 1250.00
MARTIN 1250.00
TURNER 1500.00
ADAMS 1100.00
JAMES 950.00
MILLER 1300.00
或者 select ename,sal from emp where sal in(800,1500,2000);
Result
ENAME SAL
---------- ---------
SMITH 800.00
TURNER 1500.00
9.模糊查询
select * from emp where ename like '%ALL%';
Result:
EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
----- ---------- --------- ----- ----------- --------- --------- ------
7499 ALLEN SALESMAN 7698 1981/2/20 1600.00 300.00 30
10.查询第二个是A开头的字母的员工信息
select * from emp where ename like '%_A%';
Result
EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
----- ---------- --------- ----- ----------- --------- --------- ------
7521 WARD SALESMAN 7698 1981/2/22 1250.00 500.00 30
7654 MARTIN SALESMAN 7698 1981/9/28 1250.00 1400.00 30
7698 BLAKE MANAGER 7839 1981/5/1 2850.00 30
7782 CLARK MANAGER 7839 1981/6/9 2450.00 10
7876 ADAMS CLERK 7788 1987/5/23 1100.00 20
7900 JAMES CLERK 7698 1981/12/3 950.00 30
11.查询薪水在800-2000之间的员工信息 并且按照部门的降序排序输出
select * from emp where sal between 800 and 2000 order by deptno desc;
EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
----- ---------- --------- ----- ----------- --------- --------- ------
7654 MARTIN SALESMAN 7698 1981/9/28 1250.00 1400.00 30
7900 JAMES CLERK 7698 1981/12/3 950.00 30
7844 TURNER SALESMAN 7698 1981/9/8 1500.00 0.00 30
7499 ALLEN SALESMAN 7698 1981/2/20 1600.00 300.00 30
7521 WARD SALESMAN 7698 1981/2/22 1250.00 500.00 30
7876 ADAMS CLERK 7788 1987/5/23 1100.00 20
7369 SMITH CLERK 7902 1980/12/17 800.00 20
7934 MILLER CLERK 7782 1982/1/23 1300.00 10
练习题
--查询部门名称为ACCOUNTING和RESEARCH的员工信息
select deptno from dept where dname in('ACCOUNTING', 'RESEARCH');
select * from emp where deptno in(select deptno from dept where dname in('ACCOUNTING', 'RESEARCH'));
--查询不是经理的员工的信息
--查询工资比10号部门都要低的员工信息
select min(sal) from emp where deptno=10;
--显示和KING同部门,工资低于FORD的雇员有哪些
select deptno from emp where ename='KING';
select sal from emp where ename='FORD';
select * from emp where deptno=(select deptno from emp where ename='KING') and sal<(select sal from emp where ename='FORD');
--找出部门30中所有的经理(MANAGER)和部门20中所有办事员(CLERK)
select ename,job from emp where deptno=30 and job='MANAGER';
select ename,job from emp where deptno=20 and job='CLERK';
select ename,job from emp where (deptno=30 and job='MANAGER') or (deptno=20 and job='CLERK');
--查询员工“SMITH”所在部门的员工,但不包含“FORD”的员工姓名、入职时间及部门编号
select deptno from emp where ename='SMITH';
select * from emp where deptno=(select deptno from emp where ename='SMITH') and ename not in('FORD');
--查询大于员工平均工资的所有员工,显示编号、姓名、工资,并按照升序排序
select avg(sal) from emp;
select empno,ename,sal from emp where sal>(select avg(sal) from emp) order by sal;
--查询员工姓名中包含“U”的员工所在部门编号下的所有员工的编号、姓名。
select empno,ename from emp where deptno=(select deptno from emp where ename like '%U%');
--查询经理“KING”下的所有员工的姓名、工资
select empno from emp where ename='KING';--7399
select ename,sal from emp where MGR=(select empno from emp where ename='KING');
--查询属于“ACCOUNTING”部门下所有的员工的部门编号、员工姓名及工作
select deptno from dept where dname='ACCOUNTING';
select deptno,ename,job from emp where deptno=(select deptno from dept where dname='ACCOUNTING');
--查询员工中包含“U”员工所在部门下的员工工资大于平均工资的员工,显示员工编号、姓名、及工资
select deptno from emp where ename like '%U%'; --30
select avg(sal) from emp; --2073.11
select * from emp where sal>(select avg(sal) from emp) and deptno=(select deptno from emp where ename like '%U%');
2018.5.9 Oracle数据库查询命令的更多相关文章
- oracle数据库查询日期sql语句(范例)、向已经建好的表格中添加一列属性并向该列添加数值、删除某一列的数据(一整列)
先列上我的数据库表格: c_date(Date格式) date_type(String格式) 2011-01-01 0 2012-03-07 ...
- python操作oracle数据库-查询
python操作oracle数据库-查询 参照文档 http://www.oracle.com/technetwork/cn/articles/dsl/mastering-oracle-python- ...
- C#连接Oracle数据库查询数据
C#连接Oracle数据库可以实现许多我们需要的功能,下面介绍的是C#连接Oracle数据库查询数据的方法,如果您对C#连接Oracle数据库方面感兴趣的话,不妨一看. using System; u ...
- 005.Oracle数据库 , 查询多字段连接合并,并添加文本内容
/*Oracle数据库查询日期在两者之间*/ SELECT PKID , OCCUR_DATE, PKID || ' 曾经沧海难为水 ' ||TO_CHAR( OCCUR_DATE, ' yyyy/m ...
- 004.Oracle数据库 , 查询多字段连接合并
/*Oracle数据库查询日期在两者之间*/ SELECT PKID , OCCUR_DATE, PKID || TO_CHAR( OCCUR_DATE, ' yyyy/mm/dd hh24:mi:s ...
- 001.Oracle数据库 , 查询日期在两者之间
/*Oracle数据库查询日期在两者之间*/ SELECT OCCUR_DATE FROM LM_FAULT WHERE ( ( OCCUR_DATE >= to_date( '2017-05- ...
- Oracle数据库——常用命令(用户管理、数据库导入导出)
--==cmd控制台==-- --==日常用户管理SQL==-- --连接到SQLPLUS >sqlplus /nolog --以dba身份连接 sql>conn / as sysdba ...
- ORACLE数据库 常用命令和Sql常用语句
ORACLE 账号相关 如何获取表及权限 1.COPY表空间backup scottexp登录管理员账号system2.创建用户 create user han identified(认证) by m ...
- Oracle数据库常用命令整理
转至:https://blog.csdn.net/creativemobile/article/details/8982164 1监听 (1)启动监听 lsnrctl start (2)停止监听 l ...
随机推荐
- 模拟一则ORA-600 [4194][][]故障并处理
环境:OEL 5.7 + Oracle 11.2.0.3 1.模拟ORA-600 [4194][][]故障 2.使用bbed处理 3.尝试启动数据库 1.模拟ORA-600 [4194][][]故障 ...
- java反射机制应用之动态代理
1.静态代理类和动态代理类区别 静态代理:要求被代理类和代理类同时实现相应的一套接口:通过代理类的对象调用重写接口的方法时,实际上执行的是被代理类的同样的 方法的调用. 动态代理:在程序运行时,根据被 ...
- codevs 3162 抄书问题
3162 抄书问题 题目描述 Description 现在要把M本有顺序的书分给K个人复制(抄写),每一个人的抄写速度都一样,一本书不允许给两个(或以上)的人抄写,分给每一个人的书,必须是连续的,比如 ...
- [Xcode 实际操作]六、媒体与动画-(12)检测UIView动画的结束事件:反转动画并缩小至不可见状态
目录:[Swift]Xcode实际操作 本文将演示UIView视图反转动画的制作,并检测其动画结束事件. 即视图在进行反转动画的同时,将移动到目标位置,并缩小至不可见状态. 在项目导航区,打开视图控制 ...
- JAVA接口详细讲解
接口 接口的概念 接口代表的是一个功能的集合,定义规范,所有的方法都是抽像方法,这是一种思想是一种规则,将这个种规则称为接口. 接口的定义 使用关键字 interface 叫做接口 修饰符 inte ...
- web前端篇:CSS使用,样式表特征,选择器
目录 web前端篇:CSS使用,样式表特征,选择器 1.CSS介绍 2.CSS使用 3.样式表特征 4.CSS选择器 5.选择器的优先级 6.练习题: web前端篇:CSS使用,样式表特征,选择器 1 ...
- hp惠普工作站 安装ESXI 从U盘启动黑屏问题
[背景] 公司新买了一套hp z238 workstation需要安装esxi,我按照以前的方法制作好U盘后插入从U盘引导,显示屏一直黑屏,这个问题困扰了我一天....在网上找了好久无果 第二天终于在 ...
- Charles使用小结
charles,抓包神器,记录几个测试过程中常用的功能 连接同一局域网的开发机 域名跳转MapRemoteSetting 抓取Https接口 1.下载3.10以上破解版,按如下步骤安装 ...
- mysql 无法启动 unkown command
1. https://serverfault.com/questions/490656/mysql-not-starting-error-usr-sbin-mysqld-unknown-option- ...
- php文件缓存数据
最近在做微信的摇一摇跑马活动,实现原理是用户摇动手机,通过ajax往数据库写入数据(小马跑的步数),然后PC端用过ajax每一秒钟从数据库中调取一次数据(小马跑的步数),然后显示在PC屏幕上,这样就会 ...