zoukankan      html  css  js  c++  java
  • Mysql 字符串分隔函数

    /**
    * 字符串分隔方法
    * 获取字符串分隔之后的数组长度
    */
    DROP FUNCTION IF EXISTS `func_get_split_total`;
    DELIMITER ;;
    CREATE FUNCTION `func_get_split_total`(
        f_string text, # 长度不够会导致临时表数据不全,# mysql字符类型varchar有长度限制(最大65535),改用text文本类型
        f_delimiter VARCHAR(5)) RETURNS int(11)
      DETERMINISTIC
      COMMENT '获取字符串分隔后的长度'
    BEGIN 
      RETURN 1+(LENGTH(f_string) - LENGTH(REPLACE(f_string,f_delimiter,''))); 
    END
    ;;
    DELIMITER ;

    /**
    * 获取字符串分隔后的对应下标的值,下标从1开始
    */
    DROP FUNCTION IF EXISTS `func_get_split_value`;
    DELIMITER ;;
    CREATE FUNCTION `func_get_split_value`(
        f_string text, # 长度不够会导致临时表数据不全,# mysql字符类型varchar有长度限制(最大65535),改用text文本类型
        f_delimiter VARCHAR(5),
        f_order INT) RETURNS varchar(255) CHARSET utf8mb4
      DETERMINISTIC
      COMMENT '获取字符串分隔后的对应下标的值,下标从1开始'
    BEGIN 
      DECLARE result VARCHAR(255) DEFAULT ''; 
      SET result = REVERSE(SUBSTRING_INDEX(REVERSE(SUBSTRING_INDEX(f_string,f_delimiter,f_order)),f_delimiter,1)); 
      RETURN result; 
    END
    ;;
    DELIMITER ;

    # # 

    SELECT func_get_split_total('A/B/C','/') ;    #   3

    SELECT func_get_split_value('A/B/C','/',1) ;   # A

  • 相关阅读:
    [ZJOI2010]count 数字计数
    小雄数
    简单筛法函数
    [Noip模拟题]lucky
    欧拉线筛
    Intern Day78
    CodeForces1360C
    CodeForces1373B
    Intern Day78
    Intern Day78
  • 原文地址:https://www.cnblogs.com/liujf-a-mad-man/p/10767000.html
Copyright © 2011-2022 走看看