两个字符串无序匹配问题
2008-08-26 12:44:04 来源:WEB开发网 闂傚倸鍊搁崐鎼佸磹閹间礁纾归柟闂寸绾惧綊鏌熼梻瀵割槮缁炬儳缍婇弻鐔兼⒒鐎靛壊妲紒鎯у⒔閹虫捇鈥旈崘顏佸亾閿濆簼绨绘い鎺嬪灪閵囧嫰骞囬姣挎捇鏌熸笟鍨妞ゎ偅绮撳畷鍗炍旈埀顒勭嵁婵犲嫮纾介柛灞捐壘閳ь剛鎳撻~婵嬪Ω閳轰胶鐤呯紓浣割儐椤戞瑩宕ョ€n喗鐓曟い鎰靛亝缁舵氨绱撻崘鈺傜婵﹤顭峰畷鎺戔枎閹搭厽袦婵犵數濮崑鎾绘⒑椤掆偓缁夌敻骞嗛悙鍝勭婵烇綆鍓欐俊鑲╃磼閹邦収娈滈柡灞糕偓鎰佸悑閹肩补鈧尙鏁栧┑鐐村灦閹稿摜绮旈悽绋课﹂柛鏇ㄥ灠閸愨偓濡炪倖鍔﹀鈧繛宀婁邯濮婅櫣绱掑Ο璇茶敿闂佺ǹ娴烽弫璇差嚕婵犳碍鏅插璺猴工瀹撳棝姊虹紒妯哄缂佷焦鎸冲畷鎴﹀箻鐠囧弶宓嶅銈嗘尰缁嬫垶绂嶉悙顒佸弿婵☆垳鍘ф禍楣冩倵濮樼偓瀚�

表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) || ',' ||
SUBSTR(V_MOTHER, (V_LENGTH - X) * 2 + 1);
END LOOP;
END IF;
--DBMS_OUTPUT.PUT_LINE(V_MOTHER);
--针对每个基本单位进行比较
FOR Y IN 1 .. V_LENM LOOP
V_MATCH := SUBSTR(P_STR2, Y * 2 - 1, 2);
SELECT SIGN(INSTR(V_MOTHER,V_MATCH ))
INTO V_NUM
FROM DUAL;
IF V_NUM = 1 THEN
V_MATECHED := TRIM(V_MATECHED||V_MATCH);
SELECT SUBSTR(V_MOTHER,1,INSTR(V_MOTHER, V_MATCH)-1)||SUBSTR(V_MOTHER,INSTR(V_MOTHER, V_MATCH)+3)
INTO V_MOTHER
FROM DUAL;
V_CNT := V_CNT + V_NUM;
--V_CNT := V_CNT + FUN_MATCH_CNT(V_MOTHER,V_MATCH);
V_MATECHED := TRIM(V_MATECHED||NVL(FUN_MATCH_CNT(V_MOTHER,V_MATCH),' '));
END IF;
END LOOP;
---DBMS_OUTPUT.PUT_LINE(V_CNT);
-- RETURN V_CNT;
RETURN TRIM(V_MATECHED);
END;
更多精彩
赞助商链接