sql语句的使用1(oracle)

4.2、sqlplus、pl/sql中的sql语句使用
  注意:以下带*的语句都已经在SQLPLUS中经过测试。
  4.2.1、如何返回系统当前日期、当前连接用户……
   * select sysdate from dual;--系统日期
   * select to_char(sysdate, 'yyyymmdd hh24:mi:ss') from dual;--格式化后的日期
   * select user from dual;--当前用户
  4.2.2、如何返回某字符的ASCI码、某asci码对应的字符
   * select ascii('N') from dual;--返回字母N的ASCI码
   * select chr('78') from dual;--返回数字78对应的字符
  4.2.3、使用decode 进行代码转换
   select decode(column, 'var_1', 'val_1', 'var_2', 'val_2'…, 'var_n', 'val_n', , 'val_x')from tab;
  4.2.4、学会使用其它常用函数trunc、trim、upper、round、replace、lower、lpad/rpad、substr、instr、translate、sys_context…在SQL语句中对值进行理想化处理。
   --对日期截取到天
   * select to_char(trunc(sysdate),'yyyymmdd hh24:mi:ss') from dual;
   --对日期截取到月
   * select to_char(trunc(sysdate,'month'),'yyyymmdd hh24:mi:ss') from dual;
   --对日期截取到年
   * select to_char(trunc(sysdate,'month'),'yyyymmdd hh24:mi:ss') from dual;
   --对数字取整到小数点左边第1位
   * select trunc(15.19,1) from dual;
   --对数字取整到小数点右边边第1位
   * select trunc(15.19,-1) from dual;
   --对日期四舍五入到天
   * select to_char(round(sysdate),'yyyymmdd hh24:mi:ss') from dual;
   --对数字四舍五入到小数点左边第1位
   * select round(15.19,1) from dual;
   --对字符串去掉左右空格
   * select trim('   a b c   ') from dual;
   --去掉数字串中的某个数字
   * select trim(0 from 00001234000) from dual;

   --将字符串中的某个字符串替换为另一个字符串(可空)
   * select replace('00001234000','0','') from dual;
   --对字符串进行一一对应的翻译
   * select translate('FA','ABCDEFG','白黑红蓝黄银灰') from dual;
   --将字符传转为大写
   * select upper('abc') from dual;
   --将字符传转为小写
   * select lower('AbC') from dual;
   --将字符串用某个字符串(本例为W)左补齐(右补齐为rpad)到指定长度(本例为10)
   * select lpad('abc',10,'W') from dual;
   --从字符串指定位置(本例为2)截取指定长度(本例为3,缺省为截取到末尾)的子串。
   * select substr('abcdef',2,3) from dual;
   --获取字符串中子串从指定位置(缺省为1)起第一次出现的位置
   * select instr('abcdedef','de',5) from dual;
      --获取当前连接的客户端环境信息,如客户端IP地址
   * select sys_context('USERENV','IP_ADDRESS') from dual;
  4.2.5、在查询语句中使用case实现分支开关语句
   * select case when '1'='1' then
              'abc'
       else
            'cba'
       end alias_name from dual;
   或:
   * select case '1' when '1' then
              'abc'
       else
            'cba'
        end alias_name from dual;

  4.2.6、如何返回表的前N行,第N~M行,按某字段排序后的前N行。
   --返回前N行
   Select * from tab where rownum<N+1;
   --返回第N~M行
   Select * from tab where rownum<M+1
   Minus
   Select * from tab where rownum<N+1;
   --返回按某字段排序后的前N行
   Select * from (select * from tab order by column desc/asc) where rownum<N+1;
   注意,“select * from tab”中的tab可以是一个查询结果集。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值