注:要是有哪个函数看不懂依次的查,慢慢就看懂了,不要先进行复杂的操纵,自己建个简单的测试一下,成功之后你自己就有自己的感觉了,要不然直接复制粘贴一脸懵逼。
上面的图片是目标拆分的代码,根据‘/’来进行拆分得到多行数据。效果如下
话不多说,上代码:
SELECT
t.targetColumn,
substring_index(
substring_index(t.sourceColumn,'/',b.help_topic_id + 1),'/' ,- 1
)
FROM
syjxdata t
JOIN mysql.help_topic b
ON b.help_topic_id < (
length(t.sourceColumn) - length(REPLACE (t.sourceColumn, '/', '')) + 1)
WHERE
1 = 1
AND t.sourcetable IS NOT NULL
AND t.sourcesystem IS NOT NULL
and t.sourceColumn is not null and t.sourceColumn <> ''
ORDER BY t.targetColumn
里面的代码看似有很多函数,实际上主体上是由mysql本身自带的mysql.help_topic这个函数库为基础上的改进,大致的意思是通过分割字符串后遍历依次得到分割后的数据。
substring_index(
substring_index(t.sourceColumn,'/',b.help_topic_id + 1),'/' ,- 1
)
substring_index函数是包含,意思是取b.help_topic_id + 1前面的所有数,最外层套一层是只取最后的数据。即使每次索引增加把前面所有的数据都包含,但是只取最新加入的一条数据。