oracle数据库sql语句常用方法总结

1.字符串拼接
用 || 来进行字符串拼接,把MU和1313拼接为MU1313
select 'MU'||'1313' from dual;

2.如果第一个数为null,则取第二个数
nvl(count(*),0) 如果第一个数为null,则取第二个数

3.to_date():作用将字符类型按一定格式转化为日期类型
具体用法:to_date(’‘2004-11-27’’,’‘yyyy-mm-dd’’),前者为字符串,后者为转换日期格
注意,前后两者要以一对应。
比如:to_date(’‘2004-11-27 13:34:43’’, ‘‘yyyy-mm-dd hh24:mi:ss’’) 将得到具体的时间

SQL>select to_date(‘2003-10-17 21:15:37’,‘yyyy-mm-dd hh24:mi:ss’) from dual

4.to_char():将日期按一定格式转换成字符类型
SQL> select to_char(sysdate,’‘yyyy-mm-dd hh24:mi:ss’’) time from dual;

5.sum 求和
sum(sal1+sal2) --两个数求和

SUM里边使用CASE WHEN 语句
--当IPTV_NBR IS NULL 为0,ELSE 为1
SUM (
CASE
WHEN IPTV_NBR IS NULL or IPTV_NBR = '' THEN
0
ELSE
1
END)

6.把1显示为1.00
select to_char(0.413488888, 'fm999,999,990.99999') as aa from dual; (fm 为了去掉前面补齐的空格)

7.distinct用于返回唯一不同的值。
select dictinct(id) from tables; --去重,获取表中不同id的值

8.decode函数的使用
(1):使用decode判断字符串是否一样
DECODE(value,if1,then1,if2,then2,if3,then3,...,else)
含义为
IF 条件=值1 THEN
    RETURN(value 1)
ELSIF 条件=值2 THEN
    RETURN(value 2)
    ......
ELSIF 条件=值n THEN
    RETURN(value 3)
ELSE
    RETURN(default)
END IF

(2)使用decode比较大小
select decode(sign(var1-var2),-1,var 1,var2) from dual
sign()函数根据某个值是0、正数还是负数,分别返回0、1、-1

9.Round函数用法:
截取数字
格式如下:ROUND(number[,decimals])
其中:number 待做截取处理的数值
decimals 指明需保留小数点后面的位数。可选项,忽略它则截去所有的小数部分,并四舍五入。如果为负数则表示从小数点开始左边的位数,相应整数数字用0填充,小数被去掉。需要注意的是,和trunc函数不同,对截取的数字要四舍五入

decode和round函数结合使用,获取数据的百分比,并保留小数点后几位
round(decode(f2.n,0,0,f1.m/f2.n*100),2)

10.rownum
rownum:伪列。顾名思义:是数据库自己创建出来的字段。
rownum是个伪列,伴随着结果集的过程而生成的字段。

对于rownum来说它是oracle系统顺序分配为从查询返回的行的编号,返回的第一行分配的是1,第二行是2,依此类推,这个伪字段可以用于限制查询返回的总行数,且rownum不能以任何表的名称作为前缀。
rownum不支持>, >=, =, between and,只支持<, <=等。

(1) rownum 对于等于某值的查询条件
如果希望找到学生表中第一条学生的信息,可以使用rownum=1作为条件。但是想找到学生表中第二条学生的信息,使用rownum=2结果查不到数据。因为rownum都是从1开始,但是1以上的自然数在rownum做等于判断是时认为都是false条件,所以无法查到rownum = n(n>1的自然数)。
SQL> select rownum,id,name from student where rownum=1;(可以用在限制返回记录条数的地方,保证不出错,如:隐式游标)
SQL> select rownum,id,name from student where rownum =2;
ROWNUM ID NAME


(2)rownum对于大于某值的查询条件
如果想找到从第二行记录以后的记录,当使用rownum>2是查不出记录的,原因是由于rownum是一个总是从1开始的伪列,Oracle 认为rownum> n(n>1的自然数)这种条件依旧不成立,所以查不到记录。

查找到第二行以后的记录可使用以下的子查询方法来解决。注意子查询中的rownum必须要有别名,否则还是不会查出记录来,这是因为rownum不是某个表的列,如果不起别名的话,无法知道rownum是子查询的列还是主查询的列。
SQL>select * from(select rownum no ,id,name from student) where no>2;
NO ID NAME


     3 200003 李三
     4 200004 赵四

(3)rownum对于小于某值的查询条件
rownum对于rownum1的自然数)的条件认为是成立的,所以可以找到记录。
SQL> select rownum,id,name from student where rownum <3;
ROWNUM ID NAME


    1 200001 张一
    2 200002 王二

查询rownum在某区间的数据,必须使用子查询。例如要查询rownum在第二行到第三行之间的数据,包括第二行和第三行数据,那么我们只能写以下语句,先让它返回小于等于三的记录行,然后在主查询中判断新的rownum的别名列大于等于二的记录行。但是这样的操作会在大数据集中影响速度。
SQL> select * from (select rownum no,id,name from student where rownum<=3 ) where no >=2;
NO ID NAME


     2 200002 王二
     3 200003 李三

11.exists
exists是判断exits后面的sql语句是否为真,若为真则整个sql句子成立,否则没有任何记录。例子:

select 1 from dual where exists (select 1 from dual where 2=1);

12.connect by
常用方法1:生成数字序列结果集

(1)使用rownum实现1到10的序列。
select rownum from dual connect by rownum<=10;

(2)使用level实现1到10的序列。
select level from dual connect by level<=10;

13.交集
intersect运算:返回查询结果中相同的部分。
14.差集
minus运算:返回在第一个查询结果中与第二个查询结果不相同的那部分行记录。
15.并集
union/union all运算:将查询的返回组合成一个结果,union合并结果并且将重复的内容取唯一,union all合并结果并且没有过滤重复内容

16.group by 分组
select子句后的任一非聚合函数字段都应来源于group by 分组语句后。
SELECT SSEX,MAX(SAGE) FROM STUDENT GROUP BY SSEX;

group by 分组是按照group by后的字段组合来进行分组的。也就是说group by后给了几个字段,就按照这几个字段组合成一条记录,若有重复的记录,就属于同一组,最后将所有的分组返回。
SELECT SNAME,SAGE FROM STUDENT GROUP BY SAGE,SNAME ORDER BY SAGE;

分组查询的筛选where和having
使用having语句筛选:
SELECT SNAME,SAGE FROM STUDENT where SSEX='男' GROUP BY SNAME,SAGE HAVING SAGE>'21'

(1)当在一个SQL中同时使用where和group by和having子句时,其执行顺序为:where>group by>having。
(2)同时where子句作用于表或者视图,having子句作用于组,having子句必须作用在group by之后

17.order by 排序
ORDER BY子句可以用来对一列或多列的结果集按升序或降序进行排序.
按照列名是一个排序顺序,可以是:
ASC表示按升序排序,默认是升序排列
DESC表示按降序排序
请注意,ORDER BY子句总是SELECT语句中的最后一个子句。

你可能感兴趣的:(oracle数据库sql语句常用方法总结)