KingbaseES V8R6C4B0021新增加以下Oracle 兼容函数。

一、bin_to_num

Oracle bin_to_num 函数用于将二进制位转换成十进制的数。

1、传入参数

test=# \df bin_to_num
List of functions
Schema | Name | Result data type | Argument data types | Type
--------+------------+------------------+---------------------+------
sys | bin_to_num | numeric | VARIADIC "any" | func

bin_to_num 传入的参数必须是 0 或 1,参数个数不限。

2、使用例子

test=# select bin_to_num(1,1,1,1,1) from dual;
bin_to_num
------------
31
(1 row) test=# select bin_to_num(1,1,1) from dual;
bin_to_num
------------
7
(1 row) test=# select bin_to_num(1,1,1,1,1,0,0,1,1) from dual;
bin_to_num
------------
499
(1 row)

二、regexp_count

1、函数参数

REGEXP_COUNT 返回pattern 在source_char 串中出现的次数。如果未找到匹配,则函数返回0。position 变量告诉Oracle 在源串的什么位置开始搜索。在开始位置之后每出现一次模式,都会使计数结果增加1。

REGEXP_COUNT (source_char, pattern [, position [, match_param]] ) ,其中 match_param 变量支持下面几个值:

  • ‘i’ 用于不区分大小写的匹配
  • ‘c’ 用于区分大小写的匹配
  • ‘n’ 允许句点(.)作为通配符去匹配换行符。如果省略该参数,则句点将不匹配换行符
  • ‘m’ 将源串视为多行。即Oracle 将^和$分别看作源串中任意位置任何行的开始和结束,而不是仅仅看作整个源串的开始或结束。如果省略该参数,则Oracle将源串看作一行。
  • ‘x’ 忽略空格字符。默认情况下,空格字符与自身相匹配。

2、使用例子

test=# select REGEXP_COUNT('GEORge','GE',1,'i')  from DUAL;
regexp_count
--------------
2
(1 row) test=# select REGEXP_COUNT('GEORge','GE',1,'c') from DUAL;
regexp_count
--------------
1
(1 row) test=# select REGEXP_COUNT('abc/36.0dfsdad;',E'/36\.0','1','c');
regexp_count
--------------
1
(1 row) test=# select REGEXP_COUNT('abc/36.0dfsdad;','/36\.0','1','c');
regexp_count
--------------
1
(1 row) --除“;” 外的字符个数
test=# select regexp_count('abc/36.0efgh;ijk','[^;]');
regexp_count
--------------
15
(1 row) test=# select regexp_count('abc/36.0efgh;ijk','[I]');
regexp_count
--------------
0
(1 row)

注意:Oracle 与 KingbaseES 的正则中 match_param 的意义有部分不同导致结果不同。

三、regexp_instr

1、函数参数

REGEXP_INSTR (source_char, pattern [, position [, occurrence [, return_option [, match_parameter ] ] ] ] )

  • source_char 搜索值的字符表达式,可以是任何数据类型CHAR,VARCHAR2,NCHAR,NVARCHAR2,CLOB或NCLOB的。
  • pattern 正则表达式
  • position 可选。搜索在字符串中的开始位置。如果省略,则默认为1,这是字符串中的第一个位置。
  • occurrence: 可选。它是模式字符串中的第n个匹配位置。如果省略,默认为1。
  • return_option:可选 指定返回的位置:如果指定0,那么将返回出现的第一个字符的位置,这是默认的;如果指定1,则返回字符之后发生的位置。
  • match_parameter 可选。它允许你修改REGEXP_INSTR功能匹配的行为。

2、使用例子

test=# SELECT REGEXP_INSTR ('World filled with love', 'with', 1, 1, 0, 'i') FROM dual;
regexp_instr
--------------
14
(1 row) test=# SELECT REGEXP_INSTR ('World filled with love', 'with', 1, 1, 1, 'i') FROM dual;
regexp_instr
--------------
18
(1 row) test=# SELECT REGEXP_INSTR ('Itmyhome', 'a|i|o|e|u') from dual;
regexp_instr
--------------
6
(1 row)

新增 Oracle 兼容函数-V8R6C4B0021的更多相关文章

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

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

  2. oracle 高级函数2

    原 oracle 高级函数 2017年08月17日 16:44:19 阅读数:1731 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/u013278 ...

  3. oracle 高级函数

    原 oracle 高级函数 2017年08月17日 16:44:19 阅读数:1731 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/u013278 ...

  4. oracle add_months函数

    oracle add_months函数 add_months 函数主要是对日期函数进行操作,举例子进行说明 add_months 有两个参数,第一个参数是日期,第二个参数是对日期进行加减的数字(以月为 ...

  5. Oracle to_date()函数的用法

    Oracle to_date()函数的用法 to_date()是Oracle数据库函数的代表函数之一,下文对Oracle to_date()函数的几种用法作了详细的介绍说明,供您参考学习. 在Orac ...

  6. Oracle over函数

    Oracle over函数   SQL code: sql over的作用及用法RANK ( ) OVER ( [query_partition_clause] order_by_clause )DE ...

  7. Oracle常用函数

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

  8. Oracle SQL函数

    Oracle将函数大致分为单行函数,聚合函数和分析函数. 单行函数分为字符函数,日期函数,转换函数,数字函数,通用函数,decode函数 一.字符函数 1)大小写控制函数 01.Lower() 全部小 ...

  9. Oracle trunc()函数的用法

    Oracle trunc()函数的用法 /**************日期********************/1.select trunc(sysdate) from dual --2013-0 ...

随机推荐

  1. BluePrism手把手教程2.0 创建流程

    2.0.1 创建流程 2.0.2 设置流程名称 2.0.3 添加流程说明 2.0.4 添加流程成功 2.0.4 打开新建的流程 RPA行业微信交流群,欢迎大家扫码加入一起交流,此群用于RPA行业技术. ...

  2. LeetCode. 812. 最大三角形面积

    812. 最大三角形面积 鞋带公式 鞋带公式,用于计算任意多边形的面积,可用于计算三角形的面积 已知 ΔABC 三个顶点的坐标 A:(x1,y1). B:(x2,y2). C:(x3,y3) 对应的矩 ...

  3. CANN算子:利用迭代器高效实现Tensor数据切割分块处理

    摘要:本文以Diagonal算子为例,介绍并详细讲解如何利用迭代器对n维Tensor进行基于位置坐标的大批量数据读取工作. 本文分享自华为云社区<CANN算子:利用迭代器高效实现Tensor数据 ...

  4. Linux关闭avahi-daemon服务

    avahi-daemon是一种Linux操作系统上运行在客户机上实施查找基于网络的Zeroconf service的服务守护进程. 该服务可以为Zeroconf网络实现DNS服务发现及DNS组播规范. ...

  5. 栈(Stack)和队列

    栈(Stack)和队列 栈是一个后进先出的线性表,它要求只在表尾进行删除和插入操作. 所谓的栈,其实就是一个特殊的线性表.表尾称为栈顶(Top),相应的表头称为栈底(Bottom). 栈的插入(Pus ...

  6. 【CSP-J 2021】总结

    前言:程不在长,能过则行.码不在多,无虫则灵.斯是信竞,惟吾爆零.线段维护快,树状跳的勤.数论剩余系,图论前向星.无数竞之推理,无物竞之劳形.大佬楼教主,超奆姚期智,神犇云:您太强了. 早上5:00就 ...

  7. day10 Map_查找与遍历

    Map 查找表 Map体现的结构是一个多行两列的表格,其中左列称为key,右列称为value. Map总是成对保存数据,并且总是根据key获取对应的value.因此我们可以将查询的条件作为key查询对 ...

  8. Solution -「Luogu 5170」类欧几里得算法

    推柿子大赛了属于是. 题目要求三个柿子,不妨分别记为: \[\begin {align} f (a, b, c, n) &= \sum \limits _{i = 0} ^{n} \lfloo ...

  9. MATLAB复习资料——浙商大管工学院适用

    包含12套复习卷,课堂PPT 下载链接:MATLAB练习模拟题库(12套).pdf - 蓝奏云 (lanzoub.com)

  10. GDOI 2022 普及组游记

    To LuoguDAY -1 期中考成绩下来了,全无了除了历史 (96) 和生物 (95) 还能看,剩下的-,语文 101.5 ,少错一道选择和断句就 107.5 了,居然比雌兔还低 数学少错一道选择 ...