Java乔晓松-oracle的条件查询和排序查询
2013-04-06 19:30
633 查看
在查询中过滤行
过滤使用WHERE
子句,将不满足条件的行过滤掉。
SELECT *|{[DISTINCT] column|expression [alias],...}
FROM table
[WHERE condition(s)];
WHERE 子句紧随 FROM
子句
WHERE 子句
SELECT employee_id, last_name, job_id, department_idFROM employees
WHERE department_id = 90 ;
字符和日期
字符和日期要包含在单引号中。字符大小写敏感,日期格式敏感。
默认的日期格式是 DD-MON-RR。
SELECT last_name, job_id, department_id
FROM employees
WHERE last_name = 'Whalen';
比较运算
SELECT last_name, salaryFROM employees
WHERE salary <= 3000;
其它比较运算
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;
逻辑运算
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_idFROM 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_dateFROM employees
ORDER BY hire_date DESC ;
按别名排序
SELECT employee_id, last_name, salary*12 annsalFROM 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的条件查询和排序查询
- oracle入门(8)——实战:支持可变长参数、多种条件、多个参数排序、分页的存储过程查询组件
- Oracle学习之路(一):oracle简介+基本sql语句+条件查询+排序数据理论与案例
- oracle心得1--oracle简介@基本sql语句@条件查询@排序数据理论与案例
- Java乔晓松-oracle的多表查询
- Mongodb 3.2 Java 显示指定字段 条件查询 分页排序
- Oracle Berkeley DB 在java中的复合条件查询
- oracle心得1--oracle简介@基本sql语句@条件查询@排序数据理论与案例
- oracle心得1--oracle简介@基本sql语句@条件查询@排序数据理论与案例
- Oracle(二)---------条件查询与排序数据
- Java乔晓松-oracle的多表查询
- JSP+Servlet+javabean+oracle实现页面多条件模糊查询
- Oracle中实现查询结果按照in中条件排序 InStr函数
- java开源框架集成常见错误之使用Criteria添加查询条件出现java.lang.ClassCastException异常
- oracle分区 前台查询条件样式
- java面试中oracle几种查询(经典)
- mongo查询过滤条件java实例($and,$or,$eq,$ne)
- mongo查询过滤条件java实例($and,$or,$eq,$ne)
- oracle查询结果指定排序规则
- java 创建连接oracle 数据库并查询数据