美文网首页
oracle数据库sql语句常用方法总结

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

作者: 测试进行中 | 来源:发表于2022-05-27 17:41 被阅读0次

    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对于rownum<n((n>1的自然数)的条件认为是成立的,所以可以找到记录。
    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语句常用方法总结

          本文链接:https://www.haomeiwen.com/subject/pvzmprtx.html