第二章 约束和排序数据(SQL基础)

第二章 约束和排序数据

1. 在 emp 表中选择工资介于 1500 到 2500 的员工的信息;
                注意:使用 between 下边界 and 上边界时,条件包括边界值;

[email protected]>select * from emp where sal between 1500 and 2500

2. 在emp表中选择位于20,30 部门的员工的信息;

[email protected]>select *from emp where deptno in (20,30);
                
                3. 在emp表中选择位于员工的名字中包含大写字符 ‘A’ 的员工的信息;

[email protected]>select * from emp where ename like ‘%A%‘;
                
                注意:如果查询的名字中包含%或者_ ,而且查询的时候又要查询这样的信息,需要用到换位码。
                注意:通配符%,表示0或者多个字符一样;通配符_,表示1个字符一样;

3.1 创建与 emp 表结构相同的表;
                        [email protected]>create table emp_n                        /* 参照emp表创建新表emp_n */
                                  2  as select * from emp where 1=2;           /* 加where 1=2 一致表结构没有数据 */

[email protected]>select * from emp_n;

3.2 添加包含通配符的测试用数据;
                [email protected]>insert into emp_n(empno,ename,sal) values(&empno,&ename,&sal);
                Enter value for empno: 1001
                Enter value for ename: ‘whwh%gogo‘
                Enter value for sal: 1000
                old   1: insert into emp_n(empno,ename,sal) values(&empno,&ename,&sal)
                new   1: insert into emp_n(empno,ename,sal) values(1001,‘whwh%gogo‘,1000)

1 row created.

[email protected]>/
                Enter value for empno: 1002
                Enter value for ename: ‘%whwh‘
                Enter value for sal: 2000
                old   1: insert into emp_n(empno,ename,sal) values(&empno,&ename,&sal)
                new   1: insert into emp_n(empno,ename,sal) values(1002,‘%whwh‘,2000)

1 row created.

[email protected]>/
                Enter value for empno: 1003
                Enter value for ename: ‘whwh_gogo‘
                Enter value for sal: 3000
                old   1: insert into emp_n(empno,ename,sal) values(&empno,&ename,&sal)
                new   1: insert into emp_n(empno,ename,sal) values(1003,‘whwh_gogo‘,3000)

1 row created.

[email protected]>/
                Enter value for empno: 1004
                Enter value for ename: ‘_gogo‘
                Enter value for sal: 4000
                old   1: insert into emp_n(empno,ename,sal) values(&empno,&ename,&sal)
                new   1: insert into emp_n(empno,ename,sal) values(1004,‘_gogo‘,4000)

1 row created.

[email protected]>commit;

Commit complete.

[email protected]>select * from emp_n;

EMPNO ENAME      JOB              MGR HIREDATE         SAL       COMM     DEPTNO
                ---------- ---------- --------- ---------- --------- ---------- ---------- ----------
                            1001 whwh%gogo                                       1000
                            1002 %whwh                                           2000
                            1003 whwh_gogo                                       3000
                            1004 _gogo                                           4000

3.3 换位码的使用方法;(此处以\作为换位码,换位码还可以指定其他字符)
                例:检索包含%的记录信息;
                [email protected]>select * from emp_n where ename like ‘%\%%‘ escape ‘\‘;
                
                         EMPNO ENAME      JOB              MGR HIREDATE         SAL       COMM     DEPTNO
                ---------- ---------- --------- ---------- --------- ---------- ---------- ----------
                            1001 whwh%gogo                                       1000
                            1002 %whwh                                           2000

[email protected]>select * from emp_n where ename like ‘%\%%‘;

例:检索以%开头的记录信息;
                [email protected]>select * from emp_n where ename like ‘\%%‘ escape ‘\‘;

EMPNO ENAME      JOB              MGR HIREDATE         SAL       COMM     DEPTNO
                ---------- ---------- --------- ---------- --------- ---------- ---------- ----------
                            1002 %whwh                                           2000

例:检索包含_的记录信息;
                [email protected]>select * from emp_n where ename like ‘%\_%‘ escape ‘\‘;

EMPNO ENAME      JOB              MGR HIREDATE         SAL       COMM     DEPTNO
                ---------- ---------- --------- ---------- --------- ---------- ---------- ----------
                            1003 whwh_gogo                                       3000
                            1004 _gogo                                           4000

例:检索以_开头的记录信息;
                [email protected]>select * from emp_n where ename like ‘\_%‘ escape ‘\‘;

EMPNO ENAME      JOB              MGR HIREDATE         SAL       COMM     DEPTNO
                ---------- ---------- --------- ---------- --------- ---------- ---------- ----------
                            1004 _gogo                                           4000

4 复合条件的使用
                        4.1 对于and条件的复合(可以将between...and...进行转换)

例:在emp表中选择工资介于2000到3000的员工的信息;
                [email protected]>select * from emp where sal>=2000 and sal<=3000;
 
                [email protected]>select * from emp where sal between 2000 and 3000;

4.2 对于or条件复合(可以将in()进行转换)
                例:在emp表中选择10号和20号部门的员工信息;
                [email protected]>select * from emp where deptno=10 or deptno=20;
                
                [email protected]>select * from emp where deptno in (10,20);

5 对于表中数据的排序
                        5.1 asc  表示按照所给字段进行升序排列(默认升序)
                                desc 表示按照所给字段进行降序排列
                例:将emp表中10号部门的员工信息按照sal列升序排列
                [email protected]>select * from emp where deptno=10;

[email protected]>select * from emp where deptno=10 order by sal asc;

[email protected]>select * from emp where deptno=10 order by sal;

例:将emp表中20号部门的员工信息按照sal列降序排列
                [email protected]>select * from emp where deptno=20 order by sal desc;

EMPNO ENAME      JOB              MGR HIREDATE         SAL       COMM     DEPTNO
                ---------- ---------- --------- ---------- --------- ---------- ---------- ----------
                            7788 SCOTT      ANALYST         7566 19-APR-87       3000                    20
                            7902 FORD       ANALYST         7566 03-DEC-81       3000                    20
                            7566 JONES      MANAGER         7839 02-APR-81       2975                    20
                            7876 ADAMS      CLERK           7788 23-MAY-87       1100                    20
                            7369 SMITH      CLERK           7902 17-DEC-80        800                    20

5.2 如果order by 后面跟多个字段,则将结果集先按照第1个字段进行排序【条件1】,
                                再按第2个字段进行排序【条件2】;
                        注意:【条件1】如果按照第1个字段分不开先后顺序的时候,才会按照第2个字段排序;
                                     asc 或者desc 影响的字段,仅仅是它紧挨着的那个字段;
                例:将emp表中10号部门的员工信息按sal降序排列,empno升序排列;
                [email protected]>select * from emp where deptno=10 order by sal desc,empno asc;

EMPNO ENAME      JOB              MGR HIREDATE         SAL       COMM     DEPTNO
                ---------- ---------- --------- ---------- --------- ---------- ---------- ----------
                            7839 KING       PRESIDENT            17-NOV-81       5000                    10
                            7782 CLARK      MANAGER         7839 09-JUN-81       2450                    10
                            7934 MILLER     CLERK           7782 23-JAN-82       1300                    10

例:将emp表中20号部门的员工信息按照empno 降序排列,sal升序排列;
                [email protected]>select * from emp where deptno=20 order by empno desc,sal asc;

EMPNO ENAME      JOB              MGR HIREDATE         SAL       COMM     DEPTNO
                ---------- ---------- --------- ---------- --------- ---------- ---------- ----------
                            7902 FORD       ANALYST         7566 03-DEC-81       3000                    20
                            7876 ADAMS      CLERK           7788 23-MAY-87       1100                    20
                            7788 SCOTT      ANALYST         7566 19-APR-87       3000                    20
                            7566 JONES      MANAGER         7839 02-APR-81       2975                    20
                            7369 SMITH      CLERK           7902 17-DEC-80        800                    20

5.3 除了可以使用字段排序,还可以使用字段所在的先后位置排序;
                确定字段在表中的先后顺序;
                [email protected]>set lines 100
                [email protected]>desc emp;

例:将emp表中10号部门的员工信息按sal降序排列,empno升序排列;
                 [email protected]>select * from emp where deptno=10 order by 6 desc,1 asc;

EMPNO ENAME      JOB              MGR HIREDATE         SAL       COMM     DEPTNO
                ---------- ---------- --------- ---------- --------- ---------- ---------- ----------
                            7839 KING       PRESIDENT            17-NOV-81       5000                    10
                            7782 CLARK      MANAGER         7839 09-JUN-81       2450                    10
                            7934 MILLER     CLERK           7782 23-JAN-82       1300                    10

例:将emp表中20号部门的员工信息按照empno 降序排列,sal升序排列;
                [email protected]>select * from emp where deptno=20  order by 1 desc,6 asc;

EMPNO ENAME      JOB              MGR HIREDATE         SAL       COMM     DEPTNO
                ---------- ---------- --------- ---------- --------- ---------- ---------- ----------
                            7902 FORD       ANALYST         7566 03-DEC-81       3000                    20
                            7876 ADAMS      CLERK           7788 23-MAY-87       1100                    20
                            7788 SCOTT      ANALYST         7566 19-APR-87       3000                    20
                            7566 JONES      MANAGER         7839 02-APR-81       2975                    20
                            7369 SMITH      CLERK           7902 17-DEC-80        800                    20

5.4 除了可以使用number 类型的字段进行排序外,还可以使用字符串或者时间类型的字段进行排序;
                         注意:字符串排序:按照字符对应的ASCII码的先后进行排序;
                                     日期排序:按照日期的先后进行排序,时间越往后越大;
                例:将emp表中员工按照job升序、ename降序进行排列;(先按Job排序,同样的job按ename降序)
                [email protected]>select * from emp  order by job asc,ename desc;

例:将emp表中员工按照 HIREDATE 升序,sal降序排列(如果HIREDATE相同,按照sal降序)
                先将HIREDATE显示格式设定
                [email protected]>alter session set nls_date_format=‘yyyy-mm-dd‘;

Session altered.

[email protected]>select * from emp order by hiredate asc,sal desc;
                    
                        6. 使用结果集中的别名进行排序;
                例:按照emp表中员工对于的年薪(sal*12)进行排序;
                [email protected]>select empno,ename,hiredate,sal*12 year_sal from emp order by year_sal desc;

注意:当然也可以按照字符串、日期对应的别名进行排序;

7. 如果排序的字段中包含null值,结果会怎么样?
                        注意:在字段进行比较大小的时候,null 值比任何值都大;
                例:emp表中员工的信息按照comm降序排列;
                [email protected]>select * from emp order by comm desc;
                    
                注意:null 值之间的排序不考虑(因为Null 和 null 之间无法比较大小)

如果我想将comm有值的部分换到上面,该怎么办?
                [email protected]>select * from emp order by comm desc nulls last;

同理:自己验证 升序 排列
                [email protected]>select * from emp
                    2  order by comm asc nulls first;

时间: 2024-10-25 06:11:10

第二章 约束和排序数据(SQL基础)的相关文章

sql系列(基础篇)-第二章 约束和排序数据

更好的看↑代码点击VIEW PLAN 第二章 约束和排序数据 1. 在 emp 表中选择工资介于 1500 到 2500 的员工的信息: 注意:使用 between 下边界 and 上边界时,条件包括边界值: [email protected]>l 1 select * from emp 2* where sal between 1500 and 2500 [email protected]>/ EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO ----

sql系列(基础)-第二章 限制和排序数据

更好的看↑代码点击VIEW PLAN 第二章 约束和排序数据 1. 在 emp 表中选择工资介于 1500 到 2500 的员工的信息: 注意:使用 between 下边界 and 上边界时.条件包括边界值: [email protected]>l 1 select * from emp 2* where sal between 1500 and 2500 [email protected]>/ EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO ----

学习笔记之--047.第二章 限制和排序数据

语法:select * |{[DISTINCT] column | expression [alias],...} FROM table [WHERE condition(s)]; select employee_id,last_name,job_id,department_id from employees where department_id=90; = > >= < <= <> BETWEEN...AND... IN(set) like is null sele

oracle学习 第二章 限制性查询和数据的排序 ——03

这里,我们接着上一小节2.6留下的问题:如果要查询的字符串中含有"_"或"%",又该怎样处理呢? 开始今天的学习. 2.7  如何使用转义(escape)操作符 可以是用个转义(escape)关键字来完成此任务.为了进行练习,我们必须先创建一个临时的表,之后再往该表中插入1行记录,其包含通配符.可能您现在还可能十分不理解例2-13和例2-14的SQL语句.没有问题,您只要照着输入就可以了. 例 2-13 SQL> CREATE TABLE dept_temp

随便玩玩之PostgreSQL(第二章)单表数据查询

未经授权不得转载 第二章 单表数据查询数据库的基本功能就是数据增查改删,倘若不可以,要她还有什么意义.数据查询功能不仅仅是查询,而且还能筛选,并且格式化显示.数据查询使用SELECT语句,本章介绍如何使用SELECT查询(列出)数据库中的数据. 2.1查询数据库cj表中全部信息方法一:使用"*"通配符查询所有数据(所有字段数据). SELECT * FROM cj; 结果如图. 方法二:制定所有字段(列名).每个字段用逗号(,)隔开. SELECT id,kc,bj,xm,yw,sx,

第二章 单表查询 T-SQL语言基础(3)

单表查询(3) 2.6 处理字符数据 字符数据的查询处理,内容包括:类型,排序规则,运算符和函数,以及模式匹配. 2.6.1 数据类型 SQL Server支持两种字符数据类型----普通字符和Unicode字符.普通字符数据类型包括CHAR和VARCHAR,Unicode字符数据类型包括NCHAR和NVARCHAR. 普通字符和Unicode字符的区别:普通字符使用一个字节来保存每个字符,而Unicode字符则需要两个字节. 注:当表示一个普通的字符常量时,只需要简单地使用单引号:'This

第二章 1.运行时数据区域

[TOC 概述 对于从事C.C++的程序开发人员来说,在内存管理领域,担负着每一个对象生命开始到终结的责任. 对于Java程序员来说,在虚拟机自动内存管理机制的帮助下,不需要为为每一个new操作去写配对的delete/free代码,不容易出现内存泄漏和内存溢出问题,由虚拟机管理内存这一切看起来都很美好.不过,也正是因为Java程序员把内存控制的权利交给了Java虚拟机,一旦出现内存泄漏和溢出的问题,如果不了解虚拟机是如何管理内存的,那么排查错误将会成为一项异常艰难的工作. 运行时数据区简介 Ja

第二章 单表查询 T-SQL语言基础(2)

单表查询(2) 2.2 谓词和运算符 T-SQL有几种不同的语言元素可以指定逻辑表达式,例如,查询过滤器(WHERE和HAVING),CHECK约束,等等. 在逻辑表达式中可以使用各种谓词(取值为TRUE,FALSE,或UNKNOWN的表达式)和运算符. T-SQL支持的谓词包括IN,BETWEEN,以及LIKE等. -- Predicates: IN, BETWEEN, LIKE SELECT orderid, empid, orderdate FROM Sales.Orders WHERE

第二章-服务契约与数据契约

服务契约 服务契约定义了服务向外界公开的功能,这些功能表现为服务操作,在SOAk ,经常需要交接一组SOAP消息,而这些消息的模式通常是在服务契约中定义的.服务契约还可以进一步定义每个服务操作的消息交换模式(请求-响应模式,单工模式,双工模式) 数据契约 通常,需要把一个或多个参数传递给一个服务操作,并等待服务操作返回一个值.消息参数的结构在数据契约中被解释为XSD Schema,而XSD Schema是WSDL文档的一问你.数据契约定义了客户端与服务之间信息交接的结构和内容. 消息契约 消息契