mysql字符串分割功能实现

目录
  • mysql字符串分割
    • 1、字符串分割函数
    • 2、创建存储过程,循环插入截取的每一条数据
  • 扩展:mysql字段的分割截取功能(模拟split)

mysql字符串分割

1、字符串分割函数

drop function if exists str_for_substr;
CREATE
    DEFINER = `root`@`%` FUNCTION `str_for_substr`(`num` int, `str` varchar(5000))
    RETURNS varchar(100) no sql
BEGIN
    /*函数功能: 把带逗号的字符串分割取出
        参数: num 要取出的字符串的索引值, 以0开始
                    str 以逗号分割的字符串
        扩展: 将###替换成其他符合,即可完成不同分隔符拆分字符串,亦可以把分隔符作为参数
  */
    SET @str_for_substr =
            SUBSTRING(
                    SUBSTRING_INDEX(str, '###', num + 1),
                    CASE num
                        WHEN 0 THEN
                                CHAR_LENGTH(
                                        SUBSTRING_INDEX(str, '###', num)
                                    ) + 1
                        ELSE
                                CHAR_LENGTH(
                                        SUBSTRING_INDEX(str, '###', num)
                                    ) + 4
                        END,
                    CASE num
                        WHEN 0 THEN
                                CHAR_LENGTH(
                                        SUBSTRING_INDEX(str, '###', num + 1)
                                    ) - CHAR_LENGTH(
                                        SUBSTRING_INDEX(str, '###', num)
                                    )
                        ELSE
                                CHAR_LENGTH(
                                        SUBSTRING_INDEX(str, '###', num + 1)
                                    ) - CHAR_LENGTH(
                                        SUBSTRING_INDEX(str, '###', num)
                                    ) - 1
                        END
                );
    RETURN @str_for_substr;
END;

2、创建存储过程,循环插入截取的每一条数据

drop procedure if exists split_str;
CREATE
    DEFINER = `root`@`%` PROCEDURE `split_str`()

BEGIN

    DECLARE cnt int default 0;
    DECLARE num int default 0;
    DECLARE i int default 0;
    DECLARE j int default 0;
    declare str varchar(4000);

#   统计当前截取字段表的数据量
    select count(1) into cnt from test;
#   循环查询每一条数据,此处可以换成游标处理
    while i<= cnt do
        select query_knowledge_list_string into str from test limit i,1;
#       查询每条数据###出现的次数
        SET num = (LENGTH(str) - LENGTH(REPLACE(str, '###', ''))) / 3;
        while j <= num do
#               循环插入截取后的数据
                INSERT INTO test1 (knowledge_name, subject_name, grade_name)
                select str_for_substr(j,str), subjectName, grade_name
                from test limit i,1;
            set j = j + 1;
            end while;
#       循环值归零
        set j = 0;
        set i = i + 1;
        end while;
END;

扩展:mysql字段的分割截取功能(模拟split)

大家好,又见面了。每次见面就说明我又解决了一个疑难杂症。今天这个问题更狠一些,又让我的sql能力有了进一步的提高。简单说我我最近为什么会有这么多的sql问题,主要原因就是我们从数据中台的hive库同步数据,而他们库里的数据实在是脏的过分,有各种你想象不到数据,而我们也推不动不了他们,没把办法就只能通过sql自己处理。

接下来看看今天的奇葩问题。我们同步过来的数据内容如下。

最可怕就是在类型的前面多了一些数字加顿号。这些内容对于我来讲是完全没有意义的,我需要的只是顿号后面的内容。那么我应该怎么处理得到后面的内容呢。最先想到的是split. 但是后来查了一下,mysql居然不支持split函数。真是让我大失所望。后来只能去找相近的函数,发现有一个INSTR() 函数,可以用来判断时段中是否包含某个字符串 ,并返回包含字符串对应的索引。在结合SUBSTR函数进行截取,就可以完美解决这个问题了。

同时还要注意,最好做下判断,只有当字段中包含这个字符串时才进行截取,不包含则不截取。最终得到的sql如下:

select
year,
case when INSTR(subtype,'、')>0 then SUBSTR(subtype,INSTR(subtype,'、')+1)
else subtype END subtype
from
xxx_table_name

最终得到结果成功。

到此这篇关于mysql字符串分割的文章就介绍到这了,更多相关mysql字符串分割内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Mysql将字符串按照指定字符分割的正确方法

    目录 前言 一:分两次查询(不是本文重点,但可以实现) 二:将file_ids字段分割成多列,类似Mysql的行转列 附:mysql如何将字符串按分隔符拆分 总结 前言 在某些场景下(比如:用户上传文件或者图片等),一般的做法是将文件信息(文件名,文件路径,文件大小等)保存到文件表(user_file)中,然后再将用户所有上传的文件的id用一个指定字符拼接然后存在表(user)中某个字段里(假设是:file_ids).在展示用户上传的文件时就直接查询文件表中就好了: -- 一般的语句是这样的,假

  • Mysql通过存储过程分割字符串为数组

    分割字符串为数组需要用到 三个mysql 的函数 : REVERSE(str) 返回颠倒字符顺序的字符串str. SUBSTRING_INDEX(str,delim,count) 返回从字符串str的第count个出现的分隔符delim之后的子串.如果count是正数,返回最后的分隔符到左边(从左边数) 的所有字符.如果count是负数,返回最后的分隔符到右边的所有字符(从右边数). REPLACE(str,from_str,to_str) 返回字符串str,其字符串from_str的所有出现由

  • MySQL里实现类似SPLIT的分割字符串的函数

    下边的函数,实现了象数组一样去处理字符串. 一,用临时表作为数组 复制代码 代码如下: create function f_split(@c varchar(2000),@split varchar(2)) returns @t table(col varchar(20)) as begin while(charindex(@split,@c)<>0) begin insert @t(col) values (substring(@c,1,charindex(@split,@c)-1)) se

  • MySQL查询字段实现字符串分割split功能的示例代码

    目录 问题背景 场景模拟 方法实现 SUBSTRING_INDEX LENGTH REPLACE SQL解析 问题背景 查询MySQL中用逗号分隔的字段[a,b,c]是否包含[a] 场景模拟 现有表[ec_logicplace],如下图所示: 要求判断数值[1]是否存在于表[ec_logicplace]中的[actual_place_id]中 方法实现 首先将[actual_place_id]字段用逗号拆分查询出来 通用模板为: SELECT SUBSTRING_INDEX( SUBSTRING

  • MySql字符串拆分实现split功能(字段分割转列)

    目录 需求描述 实现的sql 案例演示 字符串拆分: SUBSTRING_INDEX(str, delim, count) 替换函数:replace( str, from_str, to_str) 获取字符串长度:LENGTH( str ) 实现的原理解析 扩展:判断外部值是否在 num列值中 文章参考 需求描述 数据库中 num字段值为: 实现的效果:需要将一行数据变成多行 实现的sql SELECT SUBSTRING_INDEX(SUBSTRING_INDEX('7654,7698,778

  • mysql字符串分割功能实现

    目录 mysql字符串分割 1.字符串分割函数 2.创建存储过程,循环插入截取的每一条数据 扩展:mysql字段的分割截取功能(模拟split) mysql字符串分割 1.字符串分割函数 drop function if exists str_for_substr; CREATE DEFINER = `root`@`%` FUNCTION `str_for_substr`(`num` int, `str` varchar(5000)) RETURNS varchar(100) no sql BE

  • PHP正则表达式匹配替换与分割功能实例浅析

    本文实例讲述了PHP正则表达式匹配替换与分割功能.分享给大家供大家参考,具体如下: 正则表达式在PHP中的作用主要包括:分割.匹配.查找与替换. 匹配功能 preg_match_all 全部匹配函数 preg_match_all (string pattern,string subject,array matches[, int flags]); 对结果的排序使 $matches[0] 为全部模式匹配的数组. 用途:截取比较精确的内容,用于采集网页,分析文本等. 替换功能 preg_replac

  • MySQL数据库分区功能的使用教程

    零,什么是数据库分区 来说一下什么是数据库分区,以mysql为例.mysql数据库中的数据是以文件的形势存在磁盘上的,默认放在/mysql/data下面(可以通过my.cnf中的datadir来查看),一张表主要对应着三个文件,一个是frm存放表结构的,一个是myd存放表数据的,一个是myi存表索引的.如果一张表的数据量太大的话,那么myd,myi就会变的很大,查找数据就会变的很慢,这个时候我们可以利用mysql的分区功能,在物理上将这一张表对应的三个文件,分割成许多个小块,这样呢,我们查找一条

  • C++常用字符串分割方法实例汇总

    本文实例汇总了C++常用字符串分割方法,分享给大家供大家参考.具体分析如下: 我们在编程的时候经常会碰到字符串分割的问题,这里总结下,也方便我们以后查询使用. 一.用strtok函数进行字符串分割 原型: char *strtok(char *str, const char *delim); 功能:分解字符串为一组字符串. 参数说明:str为要分解的字符串,delim为分隔符字符串. 返回值:从str开头开始的一个个被分割的串.当没有被分割的串时则返回NULL. 其它:strtok函数线程不安全

  • Mysql字符串字段判断是否包含某个字符串的2种方法

    假设有个表: 复制代码 代码如下: CREATE TABLE users(id int(6) NOT NULL AUTO_INCREMENT,PRIMARY KEY (id),user_name VARCHAR(20) NOT NULL,emails VARCHAR(50) NOT NULL); 初始化表,并添加些记录. 复制代码 代码如下: truncate table users INSERT INTO users(user_name, emails) VALUES('小张','a@emai

  • php字符串分割函数用法实例

    本文实例讲述了php字符串分割函数用法.分享给大家供大家参考.具体分析如下: php中explode 和 split 函数用来分割字符串. explode函数语法如下 explode(substring, string) explode函数通过子字符串进行分割,效率比split要高 split函数语法如下 split(pattern, string) split通过正则表达式对字符串进行分割,效率相对explode要低,但是功能强大 <?php $list = explode("_&quo

  • C++的字符串分割函数的使用详解

    经常碰到字符串分割的问题,这里总结下,也方便我以后使用. 一.用strtok函数进行字符串分割 原型: char *strtok(char *str, const char *delim); 功能:分解字符串为一组字符串. 参数说明:str为要分解的字符串,delim为分隔符字符串. 返回值:从str开头开始的一个个被分割的串.当没有被分割的串时则返回NULL. 其它:strtok函数线程不安全,可以使用strtok_r替代. 示例: //借助strtok实现split #include <st

  • php利用scws实现mysql全文搜索功能的方法

    本文实例讲述了php利用scws实现mysql全文搜索功能的方法.分享给大家供大家参考.具体方法如下: scws这样的中文分词插件比较不错,简单的学习了一下,它包涵一些专有名称.人名.地名.数字年代等规则集合,可以直接将语句按这些规则分开成一个一个关键词,准确率在90%-95%之间,按照安装说明把scws的扩展放入php的扩展目录里,下载规则文件和词典文件,并在php配置文件中引用它们,就可以用scws进行分词了. 1) 修改 php 扩展代码以兼容支持 php 5.4.x 2) 修正 php

随机推荐