ORACLE常用函数的使用方法


1. 字符串函数

(1) length(); 获取字符长度
SELECT LENGTH('中国') FROM PLATFORM_METAINFO_TABLES WHERE TABLE_NAME = 'XMBM'  
(2) lengthb(); 获取字节长度
 SELECT LENGTHB('中国') FROM PLATFORM_METAINFO_TABLES WHERE TABLE_NAME = 'XMBM' (一个汉字等于两个字节)
(3) ltrim();  除去左边出现的字符串
SELECT LTRIM(TABLE_NAME) FROM PLATFORM_METAINFO_TABLES WHERE TABLE_NAME = 'XMBM' //除去左边的空格
SELECT LTRIM(TABLE_NAME, 'XMB') FROM PLATFORM_METAINFO_TABLES WHERE TABLE_NAME = 'XMBM' //除去左边匹配到的字符XMB
(4) rtrim();  除去右边出现的字符串
SELECT RTRIM(TABLE_NAME) FROM PLATFORM_METAINFO_TABLES WHERE TABLE_NAME = 'XMBM' //除去右边的空格
SELECT RTRIM(TABLE_NAME, 'XMB') FROM PLATFORM_METAINFO_TABLES WHERE TABLE_NAME = 'XMBM' //除去右边匹配到的字符XMB
(5) trim();   一般都是用在删除字符串两边的空格
SELECT TRIM(TABLE_NAME) FROM PLATFORM_METAINFO_TABLES WHERE TABLE_NAME = 'XMBM' //除去字段两边出现的空格
SELECT TRIM(LEADING 'M' FROM TABLE_NAME) FROM PLATFORM_METAINFO_TABLES WHERE TABLE_NAME = 'XMBM' //删除左边出现的指定的字符M
SELECT TRIM(TRAILING 'M' FROM TABLE_NAME) FROM PLATFORM_METAINFO_TABLES WHERE TABLE_NAME = 'XMBM' //删除右边出现的指定的字符M
SELECT TRIM(BOTH 'M' FROM TABLE_NAME) FROM PLATFORM_METAINFO_TABLES WHERE TABLE_NAME = 'XMBM'  //删除两边出现的指定字符M
(6) lpad(string,n,[pad_string]);在字符串左边填充特定的字符
    String是原始字符串, n 要返回的字符串长度, 从字符串末尾向前数
    当pad_String为null时, 会填充空格
(7) rpad(string,n,[pad_string]);在字符串右边填充特定的字符
    使用与lpad一样
(8) substr(); 字符串截取
SELECT SUBSTR(TABLE_NAME, 1 , 4) FROM PLATFORM_METAINFO_TABLES WHERE XMBM = 'XMBM' //截取从索引1开始的4个字符,结合length()函数可实现从左边截取
SELECT  SUBSTR(TABLE_NAME, length(TABLE_NAME)- 3 + 1,  3) FROM PLATFORM_METAINFO_TABLES WHERE TABLE_NAME = 'XMBM'
2. 时间函数

设置时间格式: ALTER SESSION SET NLS_DATE_FORMAT = 'dd-mon-yyyy HH:mi:ss'
(1) sysdate   //系统时间
(2) current_date   //系统时间
(3) to_char(sysdate, 'yyyy-mm-dd HH24:mi:ss'); //将日期转为字符串
(4) to_date('2017-09-22 00:00:00', 'yyyy-MM-dd HH24:mi:ss');  //将字符串转为日期格式
(5) TO_TIMESTAMP();转为时间戳格式, 使用类似于to_date()
SELECT TO_TIMESTAMP(to_char(SYSDATE, 'yyyy-MM-dd HH24:mi:ss'), 'yyyy-MM-dd HH24:mi:ssxff') FROM  RSGL_RYJBXXB  WHERE XMPY = 'wjw_chengqiong'
时间计算:
 >> 过去一小时/一分钟/一秒
    SELECT TO_CHAR(to_date('2019/06/04 14:43:51', 'yyyy/MM/dd hh24:mi:ss') - 1/24, 'yyyy/MM/dd hh24:mi:ss') FROM RSGL_RYJBXXB WHERE XMPY = 'wjw_chengqiong'
 >> 过去一天
    SELECT TO_CHAR(SYSDATE - 1, 'yyyy/MM/dd hh24:mi:ss') FROM RSGL_RYJBXXB WHERE XMPY = 'wjw_chengqiong'
 >> 过去一个月
    SELECT add_months(SYSDATE, -1) FROM RSGL_RYJBXXB  WHERE XMPY = 'wjw_chengqiong'

3.聚合函数

聚合函数不能作为WHERE里的查询条件出现, 因为聚合函数是对所有查询结果的运算
  (1) SUM求和
  SELECT SUM(MATTER_CNSX) FROM  SP_MATTERS
  (2) AVG求均值
  SELECT AVG(MATTER_CNSX) FROM  SP_MATTERS  
  (3) MAX和MIN
  SELECT MIN(MATTER_CNSX) FROM  SP_MATTERS  
  (4) NVL null值判断
  SELECT NVL(MATTER_CNSX, '111111111') FROM  SP_MATTERS  
  (5) ROUND四舍五入
  SELECT ROUND (AVG(MATTER_CNSX)) FROM  SP_MATTERS
  SELECT  round(AVG(MATTER_CNSX) * 100) / 100 FROM  SP_MATTERS  (保留小数点几位)  
  (6) count(*) 查询表行数
  (7) count(column) 查询列行数 , 会忽略null值

4. 关于sql的优化法则

这些优化方式来源于网友的总结,自己在这里也记录一下

(1) 尽量少用IN操作符,基本上所有的IN操作符都可以用EXISTS代替。
   原因:Oracle在执行IN子查询时,首先执行子查询,将查询结果放入临时表再执行主查询。
   而EXIST则是首先检查主查询,然后运行子查询直到找到第一个匹配项。
   NOT EXISTS 比 NOT IN 效率稍高。但具体在选择IN或EXIST操作时,
   要根据主子表数据量大小来具体考虑。
   SELECT * FROM SP_MATTERS WHERE UUID IN (SELECT UUID FROM SP_MATTERS)
   SELECT * FROM SP_MATTERS WHERE EXISTS (SELECT UUID FROM SP_MATTERS WHERE UUID = SP_MATTERS.UUID)
  (2) 不用"<>"或者"!="操作符, 对于不等于操作符会造成全表扫描, 应该用">" OR "<" 代替
  (3) is null 或者 is not null 条件会造成全表扫描, 解决方案可以为该列设置非空索引,就可以利用其它条件判断
  (4) 在like后面出现通配符 "%" 或者 "_" 时, 索引会失效, 造成全表扫描
  (5) 对于有连接的列"||",最后一个连接列索引无效, 尽量避免连接, 可以分开连接或者使用不作用在列上的函数替代
  (6) 如果索引不是基于函数的,那么当在where子句中对索引列使用函数时, 索引不再起作用
  (7) 对数据类型不同的列进行比较时,会使索引失效
  (8) >= 比 >的执行效率高, 原因: >= 会通过索引快速定位等于项, 然后再向下扫描, 选出大于项, 而> 直接走全表扫描
  (9) union和union all的区别
    union会对结果进行筛选, 消除重复, 数据量大的情况下可能会引起磁盘排序, 如果不删除重复记录
    应该使用union all
  (10) oracle从下到上多个查询条件时, 应该将过滤量最大的条件放在where子句的末尾
  (11) oracle 从右到左处理from后面的多个表时, 应该将数据量最少的表放在最后
  (12) order by 语句中的非索引列会降低性能, 可以将排序列添加索引
  (13) 当前sql连接多个表时, 使用表的别名, 并将之作为每列的前缀, 这样可以减少解析时间

ORACLE常用函数的使用方法的更多相关文章

  1. Oracle常用函数:DateDiff() 返回两个日期之间的时间间隔自定义函数

    首先在oracle中没有datediff()函数可以用以下方法在oracle中实现该函数的功能:1.利用日期间的加减运算天:ROUND(TO_NUMBER(END_DATE - START_DATE) ...

  2. Oracle常用函数

    前一段时间学习Oracle 时做的学习笔记,整理了一下,下面是分享的Oracle常用函数的部分笔记,以后还会分享其他部分的笔记,请大家批评指正. 1.Oracle 数据库中的to_date()函数的使 ...

  3. oracle常用函数总结(二)

    之前也有写过“oracle常用函数总结(一)”,为了尽量找全常见oracle函数,笔者特意查找了相关资料来作为参考,下边给大家罗列出来,部分和之前有重复的,希望能帮到大家! 列举了31个函数和1个分组 ...

  4. oracle常用函数总结

    Oracle常用函数总结 ---oracle常用函数-----一.数值型常用函数----取整数--select floor(10.1) from dual;--将n四舍五入,保留小数点后m位(默认情况 ...

  5. oracle常用函数整理

    oracle常用函数整理    1.绝对值.取余.判断数值正负函数    绝对值:ABS(n)        示例: SELECT ABS(100),ABS(-100),ABS('100') FROM ...

  6. oracle常用函数积累

    --oracle常用函数积累-- --1.字符串长度:LENGTH ,语法: CONCAT(string) --示例 select LENGTH('AA_BB') from dual;--结果:5 - ...

  7. SQL操作数据——SQL组成,查询基础语法,where,Oracle常用函数等

    SQL组成 DML数据操作语言 DCL数据控制语言 DQL数据查询语言 DDL数据定义语言 查询基础语法 记录筛选 where 子句 记录筛选 where 子句 实例练习 实例练习 Select语句中 ...

  8. 十、oracle 常用函数

    一.字符函数字符函数是oracle中最常用的函数,我们来看看有哪些字符函数:lower(char):将字符串转化为小写的格式.upper(char):将字符串转化为大写的格式.length(char) ...

  9. oracle 常用函数汇总

    一.字符函数字符函数是oracle中最常用的函数,我们来看看有哪些字符函数:lower(char):将字符串转化为小写的格式.upper(char):将字符串转化为大写的格式.length(char) ...

随机推荐

  1. RPC的发展历史(本质就是双方定义好协议,传递参数后远程调用)

    服务器通讯原理就是一台socket服务器A,另一台socket客户端B,现在如果要通讯的话直接以流方式写入或读出. 这样能实现通讯,但有个问题.如何知道更多信息?比如需要发送流大小,编码,Ip等. 这 ...

  2. 发现意外之美 - SwiftyJSON 源码学习 | 咖啡时间

    SwiftyJSON 是一个很优秀 Swift 语言第三方库.我们在之前的文章中对它有过介绍.相信大家对它也有了一些了解.提升开发功力最好的方式就是学习优秀的源代码了,记得大神 TJ Holowayc ...

  3. 2-22-实现jsp通过tomcat连接mysql

    所有软件的版本如下: MySQL-Connector-Java: mysql-connector-java-5.1.36 Tomcat: apache-tomcat-8.0.26 JDK: jdk-8 ...

  4. 基于IOCP的高速文件传输代码

    //服务端: const   //transmit用的参数   TF_USE_KERNEL_APC     = $20;   //命令类型   CMD_CapScreen             =  ...

  5. liunx 桥接 上网 ip配置 外部网络访问

    一.设置VMware 在vmware的[编辑]-->[虚拟网络编辑器]设置:将VMnet0设置为“桥接”,并桥接到宿主机器的网卡(可以是有线或者无线网络).   二.设置虚拟机系统(以cento ...

  6. comtextMenu 如何正确的响应MouseLeave事件

    今天给菜单加上这个事件,发现弹出菜单后 鼠标怎么动都不会触发 mouseLeave事件 解决方法是 在菜单loaded事件中,利用visualTreeHelper 访问他内部的border控件,把这个 ...

  7. 零元学Expression Blend 4 - Chapter 13 用实例了解布局容器系列-「Pathlistbox」I

    原文:零元学Expression Blend 4 - Chapter 13 用实例了解布局容器系列-「Pathlistbox」I 本系列将教大家以实做案例认识Blend 4 的布局容器,此章介绍的布局 ...

  8. UWP开发-获取设备唯一ID

    EasClientDeviceInformation deviceInfo = new EasClientDeviceInformation(); this.showDeviceInfo.Items. ...

  9. SQL语法详解

    ALTER DATABASE修改数据库全局特性 ALTER DATABASE实际上是修改数据库目录中的dp.opt文件 ALTER TABLE修改表的结构 ALTER TABLE对表进行增删列,创建取 ...

  10. Visual studio调试Web发生未能正常启动IIS express

    今天调试web时,不知道怎么搞的,昨天还好好的,结果今天怎么也没法调试了.VS里报的错误是进程号为**的未能正常启动,看了下调试时IIS压根就没启动起来,没关系,看看事件管理器里发生了什么 找到个最关 ...