当前位置:Gxlcms > 数据库问题 > Oracle学习日记【4】

Oracle学习日记【4】

时间:2021-07-01 10:21:17 帮助过:53人阅读

    1.查询所返回的列数以及列的类型必须匹配,列名可以不同。

    2.只有UNION ALL不会去重。其他三个都需要排序后去重,性能比较差。

2、连接查询

  2.1、内连接(INNER JOIN):INNER可省略

       语法结构:SELECT 列名 FROM 表1 INNER JOIN 表2 ON 关联条件

    SELECT 列名 FROM 表1 , 表2 WHERE 关联条件

       栗子:查询部门名称为‘SALES‘的所有员工信息

    SELECT * FROM EMP E JOIN DEPT D ON E.DEPTNO=D.DEPTNO AND D.DNAME=‘SALES‘;

    SELECT * FROM EMP E , DEPT D WHERE E.DEPTNO=D.DEPTNO AND D.DNAME=‘SALES‘;

2.2、外连接(OUTER JOIN):OUTER可省略

       2.2.1 左关联:SELECT 列名 FROM 表1 LEFT JOIN 表2 ON 关联条件

       2.2.2 右关联:SELECT 列名 FROM 表1 RIGHT JOIN 表2 ON 关联条件

       2.2.3 全外关联:SELECT 列名 FROM 表1 FULL JOIN 表2 ON 关联条件

       栗子:查询各部门名称,及对应的经理名称

    SELECT D.DNAME, E.ENAME FROM DEPT D LEFT JOIN EMP E ON D.DEPTNO = E.DEPTNO AND E.JOB = ‘MANAGER‘;

  注意:WHERE和ON的区别:不管是WHERE 还是ON,Oracle都会把能过滤的条件先过滤掉,再关联。但两者区别在于,如果是内关联,两种结果相同,如果是外关联,结果会不同,ON会保留主表的所有信息,而WHERE可能会过滤掉部分主表信息。

3、子查询和常用函数

  3.1 单行子查询:不向外部返回结果,或者只返回一行结果。

3.2 多行子查询:向外部返回零行、一行或者多行结果。

  栗子1:查询出销售部(SALES)下面的员工姓名,工作,工资。

    SELECT E.ENAME, E.JOB, E.SAL FROM EMP E WHERE E.DEPTNO = (SELECT D.DEPTNO FROM DEPT D WHERE DNAME = ‘SALES‘);

    解析:内部查询结果作为外部查询条件

  注意:1、如果内部查询不返回任何记录,则外部条件中字段DEPTNO与NULL比较永远为假,也就是说外部查询不返还任何结果。

     2、在单行子查询中外部查询可以使用=、>、<、>=、<=、<>等比较运算符。

     3、内部查询返回的结果必须与外部查询条件中的字段(DEPTNO)匹配。

     4、如果内部查询返回多行结果则出现错误。

                栗子2:查询EMP表中每个部门的最低工资的员工信息

      SELECT E.* FROM EMP E WHERE E.SAL IN (SELECT MIN(A.SAL) FROM EMP A WHERE E.DEPTNO = A.DEPTNO);

4、Oracle中的伪列

  4.1、ROWID:ROWID为返回该列的物理地址,使用ROWID可以快速定位表中某一行,可以唯一标识表中的一行

    语法结构:删除重复数据,相同数据只保留一条

    DELETE FROM EMP E

    WHERE ROWID NOT IN

    (SELECT MIN(ROWID) FROM EMP E GROUP BY EMPNO);

  4.2、ROWNUM:ROWNUM为结果集中每一行标识一个行号,第一行返回1,第二行返回2,以此类推;可以限制查询结果集中返回的行数。

    栗子:查询出员工表中前5名员工的姓名,工作,工资

      SELECT ROWNUM, E.ENAME, E.JOB, E.SAL FROM EMP E WHERE ROWNUM <= 5;

    注意:ROWNUM与ROWID不同,ROWID是插入记录是生成,ROWNUM是查询数据时生成。前者返回行物理地址,后者返回查询结果行的次序。

5、单行函数

  定义:对每一个函数应用在表的记录中时,只能输入一行结果,返回一个结果。

  常用单行函数有:

    1、   字符函数:对字符串操作

    2、   数字函数:对数字进行计算,返回一个数字

    3、   转换函数:可以将一种数据类型转换为另外一种数据类型

    4、   日期函数:对日期和时间进行处理

  5.1、字符函数

         常用字符函数:

函数

说明

ASCII(x)

返回字符x的ASCII码。

CONCAT(x,y)

连接字符串x和y。

INSTR(x, str [,start] [,n])

在x中查找str,可以指定从start开始,第n次出现。

LENGTH(x)

返回x的长度。

LOWER(x)

x转换为小写。

UPPER(x)

x转换为大写。

LTRIM(x[,trim_str])

把x的左边截去trim_str字符串,缺省截去空格。

RTRIM(x[,trim_str])

把x的右边截去trim_str字符串,缺省截去空格。

TRIM([trim_str FROM] x)

把x的两边截去trim_str字符串,缺省截去空格。

REPLACE(x,old,new)

在x中查找old,并替换为new。

SUBSTR(x,start[,length])

返回x的字串,从staart处开始,截取length个字符,缺省length,默认到结尾。

       栗子:

示例

示例结果

SELECT ASCII(‘a‘) FROM DUAL

97

SELECT CONCAT(‘Hello‘, ‘ world‘) FROM DUAL

Hello world

SELECT INSTR(‘Hello world‘,‘or‘) FROM DUAL

8

SELECT LENGTH(‘Hello‘) FROM DUAL

5

SELECT LOWER(‘hElLO‘) FROM DUAL;

hello

SELECT UPPER(‘hello‘) FROM DUAL

HELLO

SELECT LTRIM(‘===HELLO===‘, ‘=‘) FROM DUAL

HELLO===

SELECT ‘==‘||LTRIM(‘   HELLO===‘) FROM DUAL

==HELLO===

SELECT RTRIM(‘===HELLO===‘, ‘=‘) FROM DUAL

===HELLO

SELECT ‘=‘||TRIM(‘   HELLO   ‘)||‘=‘ FROM DUAL

=HELLO=

SELECT TRIM(‘=‘ FROM ‘===HELLO===‘) FROM DUAL

HELLO

SELECT REPLACE(‘ABCDE‘,‘CD‘,‘AAA‘) FROM DUAL

ABAAAE

SELECT SUBSTR(‘ABCDE‘,-2) FROM DUAL

DE

SELECT SUBSTR(‘ABCDE‘,2,3) FROM DUAL

BCD

  DUAL是一张虚拟表,只有一行一列,用来构成SELECT语法规则

       栗子2:

    ASCII(x):SELECT ASCII(ENAME) FROM EMP WHERE ENAME=‘SMITH‘;

    CONCAT(x,y):SELECT CONCAT(ENAME, JOB) FROM EMP WHERE ENAME = ‘SMITH‘;

    INSTR(x, str [,start] [,n]):SELECT INSTR(‘Hello world‘ , ‘or‘) FROM DUAL;

    LENGTH(x):SELECT LENGTH(ENAME) FROM EMP WHERE ENAME = ‘SMITH‘;

    LOWER(x):SELECT LOWER(ENAME) FROM EMP WHERE ENAME = ‘SMITH‘;

    UPPER(x):SELECT UPPER(ENAME) FROM EMP WHERE ENAME = ‘zhangsan‘;

    LTRIM(x[,trim_str]):SELECT * FROM STUDENT WHERE LTRIM(SNAME, ‘张‘) != SNAME;

    RTRIM(x[,trim_str]):SELECT * FROM EMP E WHERE RTRIM(E.ENAME,‘S‘)<>E.ENAME;

    TRIM([trim_str FROM] x):SELECT RTRIM(‘===HELLO===‘, ‘=‘) FROM DUAL

    REPLACE(x,old,new):UPDATE EMP SET ENAME = REPLACE(ENAME, ‘S‘, ‘T‘);

    SUBSTR(x,start[,length]):SELECT * FROM STUDENT WHERE SUBSTR(SNAME, 1, 1) = ‘张‘;

5.2、数字函数

       常用函数:

函数

说明

示例

ABS(x)

x绝对值

ABS(-3)=3

MOD(x,y)

x除以y的余数

MOD(8,3)=2

POWER(x,y)

x的y次幂

POWER(2,3)=8

ROUND(x[,y])

x在第y位四舍五入

ROUND(3.456,2)=3.46

TRUNC(x[,y])

x在第y位截断

TRUNC(3.456,2)=3.45

       说明:ROUND(X[,Y]),四舍五入;TRUNC(x[,y]),直接截取,不四舍五入。

5.3、日期函数

  常用的日期函数有:

  5.3.1、ADD_MONTHS(d,n),在某一个日期d上,加上指定的月数n,返回计算后的新日期。d表示日期,n表示要加的月数。

  栗子:SELECT add_months(to_date(‘2019/1/1‘,‘yyyy/mm/dd‘),6) FROM dual;

  5.3.2、LAST_DAY(d),返回指定日期当月的最后一天。

  栗子:SELECT last_day(to_date(‘2019/1/1‘,‘yyyy/mm/dd‘)) FROM dual;

  5.3.3、ROUND(d[,fmt]),返回一个以fmt为格式的四舍五入日期值,d是日期,fmt是格式模型。默认fmt为DDD,即月中的某一天。

  栗子:

  5.3.3.1、如果fmt为“YEAR”则舍入到某年的1月1日,即前半年舍去,后半年作为下一年。

    SELECT ROUND(to_date(‘2019/5/5‘,‘yyyy/mm/dd‘),‘year‘) FROM dual;

  5.3.3.2、如果fmt为“MONTH”则舍入到某月的1日,即前月舍去,后半月作为下一月。

    SELECT ROUND(to_date(‘2019/1/18‘,‘yyyy/mm/dd‘),‘month‘) FROM dual;

  5.3.3.3、默认为“DDD”,即月中的某一天,最靠近的天,前半天舍去,后半天作为第二天。

    SELECT ROUND(to_date(‘2019/1/5‘,‘yyyy/mm/dd‘),‘ddd‘) FROM dual;

  5.3.3.4、如果fmt为“DAY”则舍入到最近的周的周日,即上半周舍去,下半周作为下一周周日。

    SELECT ROUND(to_date(‘2019/1/5‘,‘yyyy/mm/dd‘),‘day‘) FROM dual;

  与ROUND对应的函数TRUNC(d[,fmt])对日期的操作,TRUNC与ROUND非常相似,只是不对日期进行舍入,直接截取到对应格式的第一天。

  栗子:

    SELECT TRUNC(to_date(‘2019/1/1‘,‘yyyy/mm/dd‘),‘day‘) FROM dual;

    SELECT TRUNC(to_date(‘2019/1/5‘,‘yyyy/mm/dd‘),‘month‘) FROM dual;

    SELECT TRUNC(to_date(‘2019/1/5‘,‘yyyy/mm/dd‘),‘year‘) FROM dual;

    SELECT TRUNC(to_date(‘2019/1/5‘,‘yyyy/mm/dd‘),’ddd’) FROM dual;

  5.4、转换函数

    5.4.1、TO_CHAR(d|n[,fmt]):把日期和数字转换为制定格式的字符串。

    栗子:SELECT TO_CHAR(SYSDATE, ‘YYYYMMDD‘) FROM DUAL

                                                SELECT TO_CHAR(123456) FROM DUAL

    5.4.2、TO_DATE(x [,fmt]):把一个字符串以fmt格式转换为一个日期类型。

    栗子:SELECT TO_DATE(‘20170703145533‘,‘YYYYMMDD HH24:MI:SS‘) FROM DUAL

    5.4.3、TO_NUMBER(x[,fmt]):把一个字符串以fmt格式转换为一个数字。

    栗子:SELECT TO_NUMBER(‘123456‘) FROM DUAL

  5.5、其他常用函数

                               

NVL(列,默认值)

如果列值为null,则使用默认值表示

NVL2(列,返回值1,返回值2)

如果列值不为null,返回结果1;

如果列值为null,返回结果2

DECODE(列|值,判断值1,返回值1,判断值2,返回值2,...,默认值)

--不是所有数据库都可用

多值判断,如果列值与判断值相同,则显示对应返回值输出,如果没有满足条件,则显示默认值

CASE WHEN 条件1 THEN 返回值1 [WHEN 条件2 THEN 返回值2 ...] ELSE 默认值 END

--所有数据库都支持

用于实现多条件判断,如果都不满足条件,则返回默认值

EXISTS(子查询)

用于判断子查询是否有数据返回,如果有则成立,否则不成立。

  栗子1:列出EMP员工的姓名,以及工作(中文)——DECODE

    SELECT E.ENAME, DECODE(E.JOB, ‘CLERK‘, ‘业务员‘, ‘SALESMAN‘, ‘销售员‘, ‘MANAGER‘, ‘经理‘, ‘ANALYST‘, ‘分析员‘, ‘PRESIDENT‘, ‘总裁‘) FROM EMP E

  CASE WHEN     :功能与DECODE相似,DECODE只用于多值判断,CASE WHEN适用于多条件判断。

  语法1:当参数的值为判断值1,则返回返回值1……当参数的值匹配不到时,则返回默认值

    CASE 参数

    WHEN 判断值1 THEN 返回值1

    WHEN 判断值2 THEN 返回值2

    ……

    ELSE 默认值 END

  语法2:当条件成立,则返回对应的返回值,没有条件成立则返回默认值

    CASE

    WHEN 条件1 THEN 返回值1

    WHEN 条件2 THEN 返回值2

    ……

    ELSE 默认值 END

  栗子2:列出EMP员工的姓名,以及工作(中文)——CASE WHEN

    SELECT E.ENAME,

    CASE E.JOB WHEN ‘CLERK‘ THEN ‘业务员‘

    WHEN ‘SALESMAN‘ THEN ‘销售员‘

    WHEN ‘MANAGER‘ THEN ‘经理‘

    WHEN ‘ANALYST‘ THEN ‘分析员‘

    WHEN ‘PRESIDENT‘ THEN ‘总裁‘

    END

    FROM EMP E

  栗子3:列出EMP员工的姓名,工资,以及工资评价——CASE WHEN

    SELECT E.ENAME, E.SAL,

    CASE WHEN E.SAL > 3000 THEN ‘工资很高‘

    WHEN E.SAL > 1000 THEN ‘工资一般‘

    ELSE ‘工资很低‘

    END

    FROM EMP E

  EXISTS(查询结果集):查询结果集有记录则成立,否则不成立。

  栗子:列出有员工的部门信息

    SELECT * FROM DEPT D WHERE EXISTS (SELECT 1 FROM EMP E WHERE D.DEPTNO = E.DEPTNO)

  注意:

    1、EXISTS、IN、关联必然可以相互转换。

    2、同理NOT EXISTS、NOT IN、外关联+从表IS NULL也能相互转换

    3、EXISTS、IN方法不会发散,但关联性能最好

 

Oracle学习日记【4】

标签:san   abs   使用   输入   lse   upper   instr   支持   方法   

人气教程排行