设为首页 收藏本站
查看: 542|回复: 0

[经验分享] sql语句的使用1(oracle)

[复制链接]

尚未签到

发表于 2016-8-8 07:16:06 | 显示全部楼层 |阅读模式
  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可以是一个查询结果集。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-254535-1-1.html 上篇帖子: oracle 存储过程中使用事务管理 下篇帖子: sql语句的使用2(oracle)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表