Java乔晓松-oracle的条件查询和排序查询

系统 1851 0

在查询中过滤行

过滤

使用 WHERE 子句,将不满足条件的行过滤掉。

SELECT *|{[DISTINCT] column|expression [alias],...}

FROM    table

[WHERE       condition(s)];

WHERE 子句紧随 FROM 子句

WHERE 子句

SELECT employee_id, last_name, job_id, department_id

FROM   employees

WHERE  department_id = 90 ;

字符和日期

字符和日期要包含在单引号中。

字符大小写敏感,日期格式敏感。

默认的日期格式是 DD-MON-RR

SELECT last_name, job_id, department_id

FROM   employees

WHERE  last_name = 'Whalen';

比较运算

SELECT last_name, salary

FROM   employees

WHERE  salary <= 3000;

其它比较运算

Java乔晓松-oracle的条件查询和排序查询

BETWEEN

使用 BETWEEN 运算来显示在一个区间内的值

SELECT last_name, salary

FROM   employees

WHERE  salary BETWEEN 2500 AND 3500;

IN

使用 IN 运算显示列表中的值。

SELECT employee_id, last_name, salary, manager_id

FROM   employees

WHERE  manager_id IN (100, 101, 201);

LIKE

使用 LIKE 运算选择类似的值

选择条件可以包含字符或数字 :

% 代表零个或多个字符 ( 任意个字符 )

_ 代表一个字符。

SELECT first_name

FROM    employees

WHERE  first_name LIKE 'S%';

‘%’ ‘-’ 可以同时使用。

 

SELECT last_name

FROM   employees

WHERE  last_name LIKE '_o%';

 

 

可以使用 ESCAPE 标识符选择 ‘%’ ‘_’ 符号。

ESCAPE

回避特殊符号的:使用转义符。例如:将 [%] 转为 [\%] [_] 转为 [\_] ,然后再加上 [ESCAPE ‘\’] 即可。

SELECT job_id

FROM   jobs

WHERE  job_id LIKE ‘IT\_%‘ escape ‘\‘;

NULL

使用 IS (NOT) NULL 判断空值。

SELECT last_name, manager_id

FROM   employees

WHERE  manager_id IS NULL;

逻辑运算

Java乔晓松-oracle的条件查询和排序查询

AND

AND 要求并的关系为真。

SELECT employee_id, last_name, job_id, salary

FROM   employees

WHERE  salary >=10000

AND    job_id LIKE '%MAN%';

OR

OR 要求或关系为真。

SELECT employee_id, last_name, job_id, salary

FROM   employees

WHERE  salary >= 10000

OR     job_id LIKE '%MAN%';

NOT

SELECT last_name, job_id

FROM   employees

WHERE  job_id

       NOT IN ('IT_PROG', 'ST_CLERK', 'SA_REP');

优先级

可以使用括号改变优先级顺序

ORDER BY子句

使用 ORDER BY 子句排序

ASC ascend : 升序

DESC descend : 降序

ORDER BY 子句在 SELECT 语句的结尾。

SELECT   last_name, job_id, department_id, hire_date

FROM     employees

ORDER BY hire_date ;

降序排序

SELECT   last_name, job_id, department_id, hire_date

FROM     employees

ORDER BY hire_date DESC ;

按别名排序

SELECT employee_id, last_name, salary*12 annsal

FROM   employees

ORDER BY annsal;

多个列排序

按照 ORDER BY 列表的顺序排序。

SELECT last_name, department_id, salary

FROM   employees

ORDER BY department_id, salary DESC;

可以使用不在 SELECT 列表中的列排序。

总结

通过本课,您应该可以完成 :

使用 WHERE 子句过滤数据

使用比较运算

使用 BETWEEN AND, IN, LIKE NULL 运算

使用逻辑运算符 AND, OR NOT

使用 ORDER BY 子句进行排序。

SELECT     *|{[DISTINCT] column|expression [alias],...}

FROM       table

[WHERE     condition(s)]

[ORDER BY  {column, expr, alias} [ASC|DESC]];

 

Java乔晓松-oracle的条件查询和排序查询


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论