SQL限定查询

1、限定查询与排序显示

1.1限定查询的认识:
列:表中有大数据的信息,对数据进行筛选,查询到自己想要的信息。
(数据过多显示过慢,或者死机,在已有的样本数据库容器CDB转换为PDB之中)
如:以nolog 的方式打开 sqlplus
Win+R 出现运行框 输入“sqlplus /nolog”
在这里插入图片描述
使用“SYS”管理员进行登陆:CONN sys/chang_on_install AS SYSDBA; 进行连接。
找到: ALTER SESSION SET CONTAINER=pdbmidn; 进行切换到 PDB 数据库。
在这里插入图片描述
数据库未打开,打开数据库pdb: ALTER DATABASE pdbmidn OPEN;
查看 sh用户的数据表内容:SELECT COUNT(*) FROM SH.SALES;
在这里插入图片描述
数据表中有9万多条数据。
直接查看数据表内容: select * from sh.sales; 数据一直显示,根本无法观看。
大数据情况下往往可以进行筛选, 筛选 就是 限定查询 的功能。

Select[distinct] * |列表名[as][列别名],列表名[as][列别名],… FROM列表名[表别名]
[WHERE 条件(S)];

出现了 WHERE 子句,可以设置一系列的过滤条件,而这些条件可以设置多个,多个条件之间可以用 逻辑运算
(与AND 多个条件同时满足即可
或 OR 一个条件满足即可
非NOT) 真变假,假变真

列; 基本工资高于1500的全部员工信息。
SELECT * FROM emp WHERE sal>1500;(满足sal>1500 条件的员工)
在这里插入图片描述
满足条件语句的员工信息全部出来了。
对于 sql 语法而言,具备三个子句:
1、执行 from ,来控制数据来源。
2、执行 where , 使用限定符进行数据的过滤。
3、执行 select , 确定要显示的数据列。

1.2对数据进行限定查询

在这里插入图片描述
关系运算符:
在这里插入图片描述
基本工资‘sal’小于等于2000: select * from emp where sal<=2000;

注: 注意大小写

调查‘SMITH’员工的信息,
在这里插入图片描述
select * from emp where ename=‘SMITH’;
查出所有办事员 [此处办事员为job] (CLERK)的雇员信息。
在这里插入图片描述
select * from emp where job=‘CLERK’;
不等于符号(<> !=)
在这里插入图片描述
实现一:select * from emp where job<>‘CLERK’;
在这里插入图片描述
实现二:select * from emp where job!=‘CLERK’;
在这里插入图片描述
查询工资在15003000(包含15003000)之间的全部雇员信息
在这里插入图片描述
select * from emp where sal>=1500 and sal<=3000;

查询职位是销售人员 SALESMAN ,并且基本工资高于1200的所有员工信息:
在这里插入图片描述
select * from emp where sal>1200 and job=‘SALESMAN’;
在这里插入图片描述
查出10部门中经理或者是20部门中的业务员信息。
SELECT * FROM emp WHERE (deptno=10 and job=‘MANAGER’) OR (deptno=20 and job=‘CLERK’);
两个条件:
1、10部门的经理。
2、20部门的办事员。
两个条件满足一条即可,两个条件之间用 or 连接。
在这里插入图片描述
在这里插入图片描述
考虑的条件:
1: 职位
2: 工资

实现一:职位不是办事员,工资大于2000.
在这里插入图片描述
SELECT * FROM emp WHERE job!=‘CLERK’ AND SAL>2000;

SELECT * FROM emp WHERE job<>‘CLERK’ AND SAL>2000;
实现二:职位是办事员,工资小于等于2000.
在这里插入图片描述
求反: SELECT * FROM emp WHERE NOT (job=‘CLERK’ OR SAL <=2000);

1.3范围查询

在这里插入图片描述
在这里插入图片描述
SELECT * FROM emp WHERE sal between 1500 and 3000;
在这里插入图片描述
查询出生在1981年雇佣的全部雇员信息:
在这里插入图片描述
SELECT * FROM emp WHERE hiredate BETWEEN ‘01-1月-81’and’31-12月-81’;
Hiredate(入职时间)
时间表示为:日-月-年。 [日期和字符串的转换]
1.4 null(空)判断
在这里插入图片描述

Null 是一个未知的数据,所以对于null的处理,如果直接利用关系运算判断,是不会有结果的,利用 = 来判断null 比较。
在这里插入图片描述
select * from emp WHERE comm=null AND empno=7369 ;
此处看出 null 不能用 = 进行判断。
一、
在这里插入图片描述
实现一:select * from emp WHERE comm is not null;
在这里插入图片描述
实现二: select * from emp WHERE not comm is null;
在这里插入图片描述
select * from emp WHERE comm is null;在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
select * from emp WHERE comm is null and sal>2000;
在这里插入图片描述
在这里插入图片描述
select * from emp WHERE comm is null or sal<100;
在这里插入图片描述
在这里插入图片描述
select distinct job from emp WHERE comm is not null;
在这里插入图片描述
在这里插入图片描述

1: select * from emp WHERE empno=7369 or empno=7788 or empno=7566;
修改为 in 输入:
2: select * from emp WHERE empno in(7369, 7788,7566 ) ;
在这里插入图片描述
select * from emp WHERE empno not in(7369, 7788,7566 ) ;
在这里插入图片描述
不能存在‘null’查询。
在这里插入图片描述


select * from emp WHERE ename LIKE ‘S%’ ;
在这里插入图片描述
在这里插入图片描述
select * from emp WHERE ename LIKE ‘M%’ ;
在这里插入图片描述
select * from emp WHERE ename LIKE ‘%F%’ ;
在这里插入图片描述
select * from emp WHERE ename LIKE '
_____%’ ;
下环线 _ 为6个。

在这里插入图片描述
select * from emp WHERE ename LIKE ‘%1%’ or hiredate LIKE ‘%81%’ ;
在这里插入图片描述
条件一: 10部门的经理
条件二: 20部门的办事员
条件三: 不是经理和办事员,但是月工资大于等于2000
条件四: 以上的所有条件满足后再过滤,包含字母 ‘S’或字母‘K’。

select * from emp WHERE
( (deptno=10 AND JOB=‘MANAGER’) OR (deptno=20 AND JOB=‘CLERK’) )
OR (JOB NOT IN (‘MANAGER’,‘CLERK’) AND SAL>2000 )
and (ename LIKE ‘%S%’ OR ENAME LIKE ‘%K%’);

一、排序显示

在这里插入图片描述
对指定的列进行排序的操作,那么就必须通过 ORDER BY 子句。
在这里插入图片描述
ORDER BY 两种排序模式:
1、升序: ASC
2、降序: DESC 需要编写
ORDER BY 子句是放在查询语句的最后一行,最后一个执行的。
顺序为:FROM, SHERE, SELECR,ORDER BY, 既然ORDER BY 在SELECT之后执行,那么表示ORDER BY 子句可以使用 select子句之中设置的别名。
在这里插入图片描述
select * from emp order by sal desc;
在这里插入图片描述
1: select * from emp order by sal;
2: select * from emp order by sal asc;
在这里插入图片描述
select * from emp where job=‘CLERK’ order by sal;
在这里插入图片描述
select * from emp order by sal DESC,hiredate ASC;
在这里插入图片描述
语法没问题,问题在于数据上,现在的数据是后期处理的结果。想要正常观察数据,那么可以数据库切换到PDB之中,找到原始的Scott 。

ALTER SESSION SET CONTAINER=pdbmidn;
ALTER DATABASE pdbmidn OPEN;
select * from scott.emp order by sal DESC,hiredate ASC;

在这里插入图片描述
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

黑白两客

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值