两个字符串无序匹配问题
表t1中有两个字段NO(NUMBER类型),ST(VARCHAR2类型)
表中有如下值
NO ST
1 ‘A1A3BCLKMBNK‘
2 ‘A2A4MBKLDMSK‘
注:ST字段中的值长度都是2的整数倍;
有一变量V_E,变量值为‘A3MLLKNKDS‘
现在将t1表中的ST字符与变量V_E进行比较,比较的方法如下:
V_E变量中每两个字符为一个基本单位,ST字段也是以两个字符为一个基本单位,让V_E与ST字段进行比较,得出ST中与V_E基本单位相同的数量
即:
t1表中的值可以看做
NO ST
1 ‘A1 A3 BC LK MB NK‘
2 ‘A2 A4 MB KL DM SK‘
. ......................................
. ......................................
---------------------------------------------
变量V_E可以看做
V_E -- ‘A3 ML LK NK DS‘
---------------------------------------------
比较之后得出:
NO ST 相同值 相同数量
1 ‘A1A3BCLKMBNK‘ A3 LK NK 3
2 ‘A2A4MBKLDMSK‘ 0
. ............................ ... .
. ............................ ... .
暂有如下函数,本人感觉效率稍低
------------------------------------------------------------------------------------------------------------------------------------CREATE OR REPLACE FUNCTION FUN_MATCH_CNT(P_STR VARCHAR2, P_STR2 VARCHAR2) RETURN VARCHAR2 IS V_MOTHER VARCHAR2(200); V_MATCH VARCHAR2(20); V_LENGTH NUMBER; V_LENM NUMBER :=2; V_NUM NUMBER := 0; V_CNT NUMBER ; V_MATCHSTR VARCHAR2(200):=‘ ‘; V_MATECHED VARCHAR2(200):=‘ ‘; BEGIN V_CNT := 0; V_MOTHER := P_STR; --V_MATCH := P_STR2; --将 V_MOTHER值改变成每两个字符被逗号隔开的值 V_LENGTH := LENGTH(REPLACE(P_STR,‘,‘,‘‘)) / 2; V_LENM := LENGTH(P_STR2) / 2; IF(INSTR(V_MOTHER,‘,‘)= 0 ) THEN FOR X IN 1 .. (V_LENGTH - 1) LOOP V_MOTHER := SUBSTR(V_MOTHER, 1, (V_LENGTH - X) * 2)
| 广告合作:400-664-0084 全国热线:400-664-0084 Copyright 2010 - 2017 www.my8848.com 珠峰网 粤ICP备15066211号 珠峰网 版权所有 All Rights Reserved
|