oracle自定义函数:将使用点分隔符的编码转成层级码格式的编码
维护一个旧的系统,表设计中只有编码,而没有其他排序相关的字段,然后根据编码排序出现了顺序错乱的问题。
详细地说,其编码设计是使用【.】分隔符的编码,比如1.1.1.1.1、1.1.1.1.2这样的格式。这时候使用编码进行排序,按照数据库字符串排序的规则,则会产生这样的问题:1.11.1排在了1.2.1的前面。这样客户就着急了,哎呀,这个排序不对啊赶紧改一改啊吧啦吧啦的。因此需要寻找解决问题的方法。因为如果从数据库取出来数据之后,再在Java里面再排序的话好像不现实,所以最后我决定还是在数据库层面上解决问题。
具体的解决方案,就是使用PL/SQL写一个自定义函数,用来将使用点分隔符的编码转成层级码格式的编码,比如1.1.1.1转成001001001。
-- 将【.】分割符的编码转成001001这样的格式
CREATE OR REPLACE FUNCTION POINT_CODE_INTO_ZARO_CODE(POINT_CODE VARCHAR2)
RETURN VARCHAR2 -- 返回类型
AS
VAR_ZERO_CODE VARCHAR2(100); -- 新编码
VAR_POINT_COUNT NUMBER := LENGTH(POINT_CODE) - LENGTH(REPLACE(POINT_CODE, '.', '')); -- 原编码中点符号的数量
VAR_THIS_POINT_INDEX NUMBER; -- 每次截取开始位置
VAR_NEXT_POINT_INDEX NUMBER; -- 每次截取结束位置
VAR_SUB_LENGTH NUMBER; -- 每次截取长度(ORACLE的字符串截取函数SUBSTR()只支持截取长度的参数,不支持截取结束位置)
VAR_PART_CODE VARCHAR2(10); -- 新编码的部分
BEGIN
-- 循环将点分隔符替换为0层级码
WHILE VAR_POINT_COUNT > 0 LOOP
VAR_THIS_POINT_INDEX := INSTR(POINT_CODE, '.', 1, VAR_POINT_COUNT); -- 取第N个点的截取位置
VAR_NEXT_POINT_INDEX := INSTR(POINT_CODE, '.', 1, (VAR_POINT_COUNT + 1)); -- 取第N+1个点的截取位置
IF VAR_NEXT_POINT_INDEX = 0
THEN
VAR_PART_CODE := SUBSTR(POINT_CODE, (VAR_THIS_POINT_INDEX + 1));
VAR_PART_CODE := LPAD(VAR_PART_CODE, '', ''); -- 左边填充0
ELSE
VAR_SUB_LENGTH := LENGTH(SUBSTR(POINT_CODE, (VAR_THIS_POINT_INDEX + 1))) -
LENGTH(SUBSTR(POINT_CODE, VAR_NEXT_POINT_INDEX));
VAR_PART_CODE := SUBSTR(POINT_CODE, (VAR_THIS_POINT_INDEX + 1), VAR_SUB_LENGTH);
VAR_PART_CODE := LPAD(VAR_PART_CODE, '', ''); -- 左边填充0
END IF;
VAR_ZERO_CODE := VAR_PART_CODE || VAR_ZERO_CODE;
VAR_POINT_COUNT := VAR_POINT_COUNT - 1;
END LOOP;
-- 最后拼接上点前面的字符串
IF VAR_ZERO_CODE IS NULL
THEN
VAR_PART_CODE := LPAD(POINT_CODE, '', ''); -- 左边填充0R
ELSE
VAR_SUB_LENGTH := LENGTH(POINT_CODE) - LENGTH(SUBSTR(POINT_CODE, INSTR(POINT_CODE, '.', 1, 1)));
VAR_PART_CODE := SUBSTR(POINT_CODE, 1, VAR_SUB_LENGTH);
VAR_PART_CODE := LPAD(VAR_PART_CODE, '', ''); -- 左边填充0R
END IF;
VAR_ZERO_CODE := VAR_PART_CODE || VAR_ZERO_CODE; RETURN VAR_ZERO_CODE;
END;
创建完自定义函数之后,就可以拿来使用了(我这里定义的是10位的层级码)。
SELECT POINT_CODE_INTO_ZARO_CODE('1.2.3') CODE FROM DUAL; --
SELECT POINT_CODE_INTO_ZARO_CODE('') CODE FROM DUAL; --
这样,在排序的时候在ORDER BY子句中加上转换后的编码,就可以实现正常排序了。
"当拥有笃定一件事并耐心长久坚持的能力,你就有了核心竞争力。"
oracle自定义函数:将使用点分隔符的编码转成层级码格式的编码的更多相关文章
- Mybatis下配置调用Oracle自定义函数返回的游标结果集
在ibatis和Mybatis对存储过程和函数函数的调用的配置Xml是不一样的,以下是针对Mybatis 3.2的环境进行操作的. 第一步配置Mapper的xml内容 <mapper names ...
- 【转】Oracle 自定义函数语法与实例
原文地址:https://blog.csdn.net/libertine1993/article/details/47264211 Oracle自定义函数的语法如下: create or replac ...
- Oracle自定义函数和存储过程示例,自定义函数与存储过程区别
参考资料:http://www.newbooks.com.cn/info/60861.html oracle自定义函数学习和连接运算符(||) 贴一段中文文档示例,应该就可以开始工作了: --过程(P ...
- Oracle自定义函数1
用户定义函数是存储在数据库中的代码块,可以把值返回到调用程序.调用时如同系统函数一样,如max(value)函数,其中,value被称为参数.函数参数有3种类型. IN 参数类型:表示输入给函数的参数 ...
- Oracle自定义函数
核心提示:函数用于返回特定数据.执行时得找一个变量接收函数的返回值; 语法如下: create or replace function function_name ( argu1 [mode1] da ...
- Oracle自定义函数&加密
在sql中频繁使用的功能(逻辑.加密等)可以写成自定义函数进行封装,之后再调用即可. CREATE OR REPLACE FUNCTION "函数名" (参数名 参数类型 参数数据 ...
- Oracle 自定义函数实现列转行效果
在 Oracle 领域,我相信一说到列转行大部分人都会立马想到 WM_CONCAT 函数,我觉得主要是因为该函数比较实用.但事实上 WM_CONCAT 并非官方公开函数,使用会存在一定的风险:函数返回 ...
- Oracle 自定义函数Function
示例代码: CREATE OR REPLACE FUNCTION "MY_DATABASE"."F_GET_USER_COUNT_BY_DEPART" ( D ...
- oracle 自定义函数
函数和存储过程类似,可以简单的理解为一段可以执行某个活动/动作的子程序,可以作为一个系统对象被存储在数据库中,可以重复调用.与存储过程不同的是,函数总是向调用者返回一个值,而存储过程不能有返回值. C ...
随机推荐
- August 25th, 2019. Sunday, Week 35th.
It's what you do next that counts, not what happens but what you decide to do about it. 重点不是发生了什么,而是 ...
- 第K个语法符号
在第一行我们写上一个 0.接下来的每一行,将前一行中的0替换为01,1替换为10. 给定行数 N 和序数 K,返回第 N 行中第 K个字符.(K从1开始) 例子: 输入: N = 1, K = 1输出 ...
- 淘宝爬取图片和url
刚开始爬取了 百度图片和搜狗图片 但是图片不是很多,随后继续爬取淘宝图片,但是淘宝反爬比较厉害 之前的方法不能用 记录可行的 淘宝爬取 利用selenium爬取 https://cloud.tence ...
- Java之多线程创建方式
多线程的由来 我们在之前,学习的程序在没有跳转语句的前提下,都是由上至下依次执行,那现在想要设计一个程序,边打游戏边听歌,怎么设计?要解决上述问题,咱们得使用多进程或者多线程来解决. 多线程的好处: ...
- 【使用篇二】配置文件application.properties参数详解(21)
springboot提供了许多启动器starter,大部分的启动器都有配置属性,这些配置属性一般可以在这里找到: xxxxxxxx-autoconfigure-xxxxx.jar/META-INF/s ...
- Comet OJ - Contest #10 B题 沉鱼落雁
###题目链接### 题目大意:有 n 个正整数,每个正整数代表一个成语,正整数一样则成语相同.同一个正整数最多只会出现 3 次. 求一种排列,使得这个排列中,相同成语的间隔最小值最大,输出这个最小间 ...
- python-schedule模块(定时任务)基于官方文档总结
一.模块安装 pip3 install schedule 官方文档 二.常用的使用案例 #基本格式 #创建方法 def func(): print("方法") #创建定时 sche ...
- git clone克隆项目太慢,或者直接导致克不下来的解决办法(转载请注明出处)
从github下载项目下来,由于项目提交历史过多等各种原因导致文件太大,clone的时候非常的慢,或者直接出现 error: RPC failed; curl 18 transfer closed w ...
- OpenCV:获取图像当中某一点的坐标
import numpy as np image=np.zeros((300,300,3),dtype='uint8') (cx,cy)=image.shape[1]//2,image.shape[0 ...
- pymysql增删改查操作
表结构 CREATE TABLE `students` ( `id` int(10) unsigned NOT NULL AUTO_INCREMENT, `name` varchar(20) DEFA ...