Oracle语句学习

 

(1)select * from dual中的dual到底是什么?

    

在sql-developer中测试发现,dual只是一个包含一列,永远只返回一条数据记录的虚拟表。使用dual,是为了构成select的语法规则。当我们需要查询一些不需要表名的数据时,但为了保证sql语法正确性,我们需要添加dual。

比如:

【1】查询当前用户

select user from dual;

【2】查询Oracle的系统时间

select sysdate from dual;


(2)trunc(number)函数

trunc()的作用是按照一定的规则截取传入的参数

【1】select trunc(123.456) from dual;    返回123    即直接去除小数位

【2】select trunc(123.456,2) from dual;    返回123.45    将小数点后2位的数字截去,说减去可能更容易理解

123.456-0.006=123.45

【3】select trunc(123.456,-2) from dual;    返回100    将小数点前2位的数字减去,即123.456-23.456=100


(3)nvl(a,b)函数

如果a为null值时,则返回b。如果a不为null值时,则返回a本来的值。

用java语言来概括就是

return a==null?b:a;


(4)sign(a)函数

如果a是负数,则返回-1

如果a是0,则返回0

如果a是正数,则返回1


(5)decode(key,x1,y1,x2,y2,.....xn,yn,defaultValue)函数

含义如下:类似于switch语句

switch(key){
    case x1:
        return y1;
    case x2:
        return y2;
    .......
    case xn:
        return yn;
    default:
        return defaultValue;
}

【1】查询某班男生和女生的数量

通常我们这么写:

select count(*) from 表 where 性别 = 男;

select count(*) from 表 where 性别 = 女;

之后好需要进行union

现在利用decode,可以这样写

select sum(decode(性别,男,1,0)),sum(decode(性别,女,1,0)) from 表


(6)listagg()函数的作用

列转行,能够将多条记录转化成一条记录,中间用特定的分隔符连接

话不多说。示例:

查看每个人身上的标签,标签之间以逗号隔开

对应的sql语句为:

 select name,listagg(tag,',') within group(order by tag) tags from table_a group by name

此时输出为:

group bu name,先按照name字段就行分组

listagg(tag,',') 实现行转列,将分组后的tag列表转化成一行记录,各个tag之间用逗号连接

within group(order by tag),tag行记录内的多个tag,升序排列


(7)||是什么意思?

相当于字符串连接,即相当于“+”

话不多说,示例:


(8)(+)代表什么?

这个要谈到左连接与右连接。

当此符号出现在连接条件的右边时,此时是左连接。

当此符号出现在连接条件的左边时,此时是右连接。

更加详细的解释见Oracle(+)号用法

不过需要注意的是,oracle中才有这种语法。mysql中是没有的,只能乖乖的写join了。