新增 Oracle 兼容函数-V8R6C4B0021
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的更多相关文章
- oracle常用函数总结(二)
之前也有写过“oracle常用函数总结(一)”,为了尽量找全常见oracle函数,笔者特意查找了相关资料来作为参考,下边给大家罗列出来,部分和之前有重复的,希望能帮到大家! 列举了31个函数和1个分组 ...
- oracle 高级函数2
原 oracle 高级函数 2017年08月17日 16:44:19 阅读数:1731 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/u013278 ...
- oracle 高级函数
原 oracle 高级函数 2017年08月17日 16:44:19 阅读数:1731 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/u013278 ...
- oracle add_months函数
oracle add_months函数 add_months 函数主要是对日期函数进行操作,举例子进行说明 add_months 有两个参数,第一个参数是日期,第二个参数是对日期进行加减的数字(以月为 ...
- Oracle to_date()函数的用法
Oracle to_date()函数的用法 to_date()是Oracle数据库函数的代表函数之一,下文对Oracle to_date()函数的几种用法作了详细的介绍说明,供您参考学习. 在Orac ...
- Oracle over函数
Oracle over函数 SQL code: sql over的作用及用法RANK ( ) OVER ( [query_partition_clause] order_by_clause )DE ...
- Oracle常用函数
前一段时间学习Oracle 时做的学习笔记,整理了一下,下面是分享的Oracle常用函数的部分笔记,以后还会分享其他部分的笔记,请大家批评指正. 1.Oracle 数据库中的to_date()函数的使 ...
- Oracle SQL函数
Oracle将函数大致分为单行函数,聚合函数和分析函数. 单行函数分为字符函数,日期函数,转换函数,数字函数,通用函数,decode函数 一.字符函数 1)大小写控制函数 01.Lower() 全部小 ...
- Oracle trunc()函数的用法
Oracle trunc()函数的用法 /**************日期********************/1.select trunc(sysdate) from dual --2013-0 ...
随机推荐
- 用python整个URL缩短器
URL缩短 短网址由于易于记忆和输入,因此在数字营销领域非常受欢迎. 这里给大家介绍一下,如何使用Python创建URL缩短器. python答疑 咨询 学习交流群2:660193417### fro ...
- 解决github.com 的响应时间过长以及hosts配置不能保存的问题
github.com 的响应时间过长 1 获取github可以使用的DNS域名 DNS查询 选择TTL值最小的 2 修改hosts配置 打开之后在最后加上如下内容,保存即可 3 出现hosts不能保存 ...
- 2019 CSP-J 初赛解析
题面,成绩不是真实水平,就挑重点说一说 老师给的解析 T5 这是二分查找,属于是我的代码理解不太对 我的理解 #include<iostream> using namespace std; ...
- 记录一下第一次在CodeForces供题的事(未完待续)
3月11日 因为想出题而开始打比赛上分 (Rating 1727) (期间最低掉到 1669) 6月4日凌晨 上分,有了权限 (Rating 2141) 6月4-6日 出了七道题 6月8-12日 又出 ...
- Selenium指定浏览器路径
ChromeOptions options = new ChromeOptions(); options.setBinary("C:\\Program Files (x86)\\Google ...
- Bash脚本debug攻略
初学Bash时, 我从未想过想过bash也能debug, 也从未想过去debug Bash脚本. 随着技术的增长, 写的脚本越来越复杂, 使用echo打印日志来调试脚本的方式越来越捉襟见肘了. 直到某 ...
- samba打开一个文件的函数调用栈
ceph_open cephwrap_open open_fn smb_vfs_call_open SMB_VFS_OPEN fd_open fd_open_atomic open_file open ...
- &&与||的优先级比较
&&与||的优先级比较类似于一种思维体操,更多的是造成矛盾,使得两者因为先后顺序的不同而造成的不同结果,当然有时候需要注意c语言中的短路运算. 方法1. 代码如下: 点击查看代码 #i ...
- 《HelloGitHub》第 76 期
兴趣是最好的老师,HelloGitHub 让你对编程感兴趣! 简介 HelloGitHub 分享 GitHub 上有趣.入门级的开源项目. https://github.com/521xueweiha ...
- vscode 个人配置 settings.json
{ "workbench.colorTheme": "Default Dark+", "workbench.iconTheme&quo ...