当前所在位置:珠峰网资料 >> 计算机 >> Oracle认证 >> 正文
Oracle认证考试辅导:两个字符串无序匹配问题
发布时间:2010/3/24 20:08:07 来源:城市学习网 编辑:admin

  两个字符串无序匹配问题
  表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