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 , 确定要显示的数据列。
关系运算符: 基本工资‘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);
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;
本文地址:http://nhjcxspj.xhstdz.com/quote/3757.html 物流园资讯网 http://nhjcxspj.xhstdz.com/ , 查看更多