文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Mysql获得两个字符串中最大相同子串的示例分析

2024-04-02 19:55

关注

今天就跟大家聊聊有关Mysql获得两个字符串中最大相同子串的示例分析,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

length:返回字符串所占的字节数,是计算字段的长度。utf8编码下,一个汉字是算三个字符,一个数字或字母算一个字符。其他编码下,一个汉字算两个字符, 一个数字或字母算一个字符。 
char_length:返回字符串所占的字符数,不管汉字还是数字或者是字母都算是一个字符

DELIMITER $$
CREATE DEFINER=`testuser`@`%` PROCEDURE `getMaxSubStrP`(`inParam1` varchar(100),`inParam2` varchar(100), out `resultStr` VARCHAR(100), out `resultLen` int)
BEGIN
   DECLARE longStr VARCHAR(255);
   DECLARE shortStr VARCHAR(255);
   DECLARE tempStr VARCHAR(255);
   DECLARE tempResult VARCHAR(255) DEFAULT "";
   DECLARE strLength2 INT DEFAULT 0;
   DECLARE strLength3 INT DEFAULT 0;
   DECLARE minStrLength INT DEFAULT 0;
   DECLARE startIndex INT DEFAULT 0;
   DECLARE endIndex INT DEFAULT 1;
   DECLARE cmpInt   INT DEFAULT 0;
    
   SELECT CHAR_LENGTH(inParam1), CHAR_LENGTH(inParam2) INTO strLength2,strLength3 FROM DUAL;
  
   SET minStrLength = strLength2;
 
   IF  minStrLength>strLength3 THEN
       SET minStrLength=strLength3;
       SET longStr =  inParam1;
       SET shortStr = inParam2;
   ELSE
       SET longStr=inParam2;
       SET shortStr=inParam1;
   end if;


   -- select minStrLength,longStr,shortStr;
   
    WHILE startIndex < minStrLength
    DO
        SET endIndex = startIndex + 1;
        WHILE endIndex<=minStrLength
        DO
              SELECT SUBSTR(shortStr,startIndex+1,endIndex-startIndex) into tempStr from DUAL;
              SELECT INSTR(longStr, tempStr ) into cmpInt FROM dual;
          -- select startIndex,endIndex,tempStr,tempResult,cmpInt;
             IF (cmpInt>0) AND (CHAR_LENGTH(tempResult)<char_length(tempstr)) then  THEN            
              SET tempResult=tempStr;
             END if;
             SET endIndex = endIndex + 1;
       end WHILE; -- endIndex while
       set startIndex = startIndex + 1;
    end while; -- startIndex WHILE
   
   set resultStr=tempResult;
   SELECT CHAR_LENGTH(resultStr) INTO resultLen FROM DUAL;
   -- set resultLen= CHAR_LENGTH(resultStr);
   -- select @resultLen,@resultStr;
END$$
DELIMITER ;

看完上述内容,你们对Mysql获得两个字符串中最大相同子串的示例分析有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注亿速云行业资讯频道,感谢大家的支持。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯