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

  • 相关阅读:
    垂直渐变的Button
    winform下重画ListBox
    分享一个 C# Winfrom 下的 OutlookBar 控件的使用
    颜色下拉菜单(combox)
    Robot Framework 使用技巧 快捷键
    Batch 拷贝远程机器文件到本机指定目录下
    JMeter常用函数 使用图解
    SoapUI报ClientProtocolException错误
    Setup Script in SoapUI
    邮件自动回复
  • 原文地址:https://www.cnblogs.com/liujf-a-mad-man/p/10767000.html
Copyright © 2011-2022 走看看