设为首页 加入收藏

TOP

Oracle学习(2):过滤和排序(二)
2015-11-21 02:05:32 来源: 作者: 【 】 浏览:3
Tags:Oracle 学习 过滤 排序
-------------
NLS_LENGTH_SEMANTICS BYTE
NLS_NCHAR_CONV_EXCP FALSE


已选择19行。


SQL> select *
2 from emp
3 where hiredate='1981-11-17';


EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
---------- -------- --------- ---------- ---------- ----- ---------- ----------
7839 KING PRESIDENT 1981-11-17 5000 10


SQL> select *
2 from emp
3 where hiredate='17-11月-81';
where hiredate='17-11月-81'
*
第 3 行出现错误:
ORA-01861: 文字与格式字符串不匹配




SQL> alter session set NLS_DATE_FORMAT='DD-MON-RR';


会话已更改。


SQL> host cls


between and 语法

SQL> --beween...and:包含边界
SQL> --查询月薪在1000~2000上的员工
SQL> --1. select * from emp where sal>=1000 and sal<=2000;
SQL> --2
SQL> select *
2 from emp
3 where sal between 1000 and 2000;


EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
---------- -------- --------- ---------- -------------- ----- ---------- ----------
7499 ALLEN SALESMAN 7698 20-2月 -81 1600 300 30
7521 WARD SALESMAN 7698 22-2月 -81 1250 500 30
7654 MARTIN SALESMAN 7698 28-9月 -81 1250 1400 30
7844 TURNER SALESMAN 7698 08-9月 -81 1500 0 30
7876 ADAMS CLERK 7788 13-7月 -87 1100 20
7934 MILLER CLERK 7782 23-1月 -82 1300 10


已选择6行。


SQL> ed
已写入 file afiedt.buf


1 select *
2 from emp
3* where sal between 2000 and 1000
SQL> /


未选定行


SQL> --between..and:小值在前,大值在后
SQL> host cls


in语法

SQL> --in:在集合中
SQL> --查询10,20号部门的员工
SQL> --1. select * from emp where deptno=10 or deptno=20;
SQL> --2.
SQL> select *
2 from emp
3 where deptno in (10,20);


EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
---------- -------- --------- ---------- -------------- ----- ---------- ----------
7369 SMITH CLERK 7902 17-12月-80 800 20
7566 JONES MANAGER 7839 02-4月 -81 2975 20
7782 CLARK MANAGER 7839 09-6月 -81 2450 10
7788 SCOTT ANALYST 7566 13-7月 -87 3000 20
7839 KING PRESIDENT 17-11月-81 5000 10
7876 ADAMS CLERK 7788 13-7月 -87 1100 20
7902 FORD ANALYST 7566 03-12月-81 3000 20
7934 MILLER CLERK 7782 23-1月 -82 1300 10


已选择8行。


SQL> ed
已写入 file afiedt.buf


1 select *
2 from emp
3* where deptno not in (10,20)
SQL> /


EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
---------- -------- --------- ---------- -------------- ----- ---------- ----------
7499 ALLEN SALESMAN 7698 20-2月 -81 1600 300 30
7521 WARD SALESMAN 7698 22-2月 -81 1250 500 30
7654 MARTIN SALESMAN 7698 28-9月 -81 1250 1400 30
7698 BLAKE MANAGER 7839 01-5月 -81 2850 30
7844 TURNER SALESMAN 7698 08-9月 -81 1500 0 30
7900 JAMES CLERK 7698 03-12月-81 950 30


已选择6行。


一个in的空值问题

SQL> ed
已写入 file afiedt.buf


1 select *
2 from emp
3* where deptno not in (10,20,null)
SQL> /


未选定行


SQL> --问题:如果集合中含有空值,为什么没有结果? (后面的文章会予以解答)
SQL> host cls

模糊查询


SQL> --like:模糊查询 % _
SQL> --查询名字以S打头的员工
SQL> select *
2 from emp
3 where ename like 'S%';


EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
---------- -------- --------- ---------- -------------- ----- ---------- ----------
7369 SMITH CLERK 7902 17-12月-80 800 20
7788 SCOTT ANALYST 7566 13-7月 -87 3000 20


SQL> --查询名字是4个字的员工
SQL> select *
2 from emp
3 where ename like '____';


EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
---------- -------- --------- ---------- -------------- ----- ---------- ----------
7521 WARD SALESMAN 7698 22-2月 -81 1250 500 30
7839 KING PRESIDENT 17-11月-81 5000 10
7902 FORD ANALYST 7566 03-12月-81 3000 20


SQL> insert into emp(empno,ename,deptno) values(1001,'Tom_123',10); (插入一行带有_的数据)


已创建 1 行。


SQL> select * from emp;


EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
---------- -------- --------- ---------- -------------- ----- ---------
首页 上一页 1 2 3 4 5 6 7 下一页 尾页 2/7/7
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇MongoDB学习(3)高级操作 下一篇Oracle基础(三)数据库管理

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: