开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 240|回复: 16
收起左侧

[已解决] mysql截取字符串并求合

 关闭 [复制链接]
结帖率:62% (16/26)
发表于 2024-11-14 13:23:07 | 显示全部楼层 |阅读模式   贵州省贵阳市
50精币
我有一个数据表(如100行),每一行有一列是保存如下格式的列;
格式为:A 名称1 B 1 C 2 D 3 E 4 F 5 G | A 名称1 B 11 C 22 D 33 E 44 F 55 G | A 名称1 B 111 C 222 D 333 E 444 F 555 G | ……
               (每段以 | 分割,有重复,且重复次数未知)


我想要截取名称为“名称1"中“E"和“F”中间的数字并求合。
如第一个“名称1”为 4 ,第二个“名称1”为 44,则这两个数相加 4+44 =48。
我现在使用“substring_index”只能截取第一个,第二个重复的就截取不到了(另外这个重复的次数不固定)
取出来分割再相加这个效率太低,有没有办法用一条SQL语句就能截取出全部符合条件的,并进行求合 sum()。

最佳答案

查看完整内容

SELECT SUM( CAST(SUBSTRING_INDEX(SUBSTRING_INDEX(t.text, 'E ', -1), ' F', 1) AS SIGNED) ) AS total_sum FROM ( SELECT SUBSTRING_INDEX(SUBSTRING_INDEX(text, ' | ', n.n), ' | ', -1) AS text FROM my_table, (SELECT 1 n UNION ALL SELECT 2 UNION ALL SELECT 3) n -- 假设每行最多有3组数据 ) t;

回答提醒:如果本帖被关闭无法回复,您有更好的答案帮助楼主解决,请发表至 源码区 可获得加分喔。
友情提醒:本版被采纳的主题可在 申请荣誉值 页面申请荣誉值,获得 1点 荣誉值,荣誉值可兑换荣誉会员、终身vip用户组。
快捷通道:申请荣誉值无答案申请取消悬赏投诉有答案未采纳为最佳
结帖率:100% (5/5)

签到天数: 14 天

发表于 2024-11-14 13:23:08 | 显示全部楼层   北京市北京市
SELECT      SUM(         CAST(SUBSTRING_INDEX(SUBSTRING_INDEX(t.text, 'E ', -1), ' F', 1) AS SIGNED)     ) AS total_sum FROM (     SELECT          SUBSTRING_INDEX(SUBSTRING_INDEX(text, ' | ', n.n), ' | ', -1) AS text     FROM          my_table,         (SELECT 1 n UNION ALL SELECT 2 UNION ALL SELECT 3) n -- 假设每行最多有3组数据 ) t;

评分

参与人数 1荣誉 +1 收起 理由
笨潴 + 1 热心帮助他人,荣誉+1,希望继续努力(*^__^*) 嘻嘻!

查看全部评分

回复

使用道具 举报

结帖率:95% (18/19)

签到天数: 23 天

发表于 2024-11-14 13:49:29 | 显示全部楼层   湖北省武汉市
分字段吧
回复

使用道具 举报

结帖率:62% (16/26)

签到天数: 4 天

 楼主| 发表于 2024-11-14 13:57:04 | 显示全部楼层   贵州省贵阳市

分字段的话  直接sum()就行了,就是不能分。
回复

使用道具 举报

结帖率:95% (18/19)

签到天数: 23 天

发表于 2024-11-14 14:31:36 | 显示全部楼层   湖北省武汉市
ysjadnt 发表于 2024-11-14 13:57
分字段的话  直接sum()就行了,就是不能分。

那你只能一条一条读出来操作了,SQL没有你说的那种命令
回复

使用道具 举报

签到天数: 3 天

发表于 2024-11-14 14:37:26 | 显示全部楼层   河北省保定市
WITH RECURSIVE split_segments AS (
    -- Step 1: 初始行分割第一段
    SELECT
        id,
        SUBSTRING_INDEX(col, '|', 1) AS segment,
        SUBSTRING_INDEX(col, '|', -1) AS remaining
    FROM your_table

    UNION ALL

    -- Step 2: 递归地拆分剩余段落
    SELECT
        id,
        SUBSTRING_INDEX(remaining, '|', 1) AS segment,
        SUBSTRING_INDEX(remaining, '|', -1) AS remaining
    FROM split_segments
    WHERE remaining LIKE '%|%'
),

-- Step 3: 提取每个段中 E 和 F 中间的数字(名称为“名称1”)
extract_values AS (
    SELECT
        id,
        segment,
        CAST(REGEXP_SUBSTR(segment, 'E ([0-9]+) F') AS UNSIGNED) AS e_value
    FROM split_segments
    WHERE segment LIKE '%A 名称1%'
)

-- Step 4: 求和
SELECT
    id,
    SUM(e_value) AS total_e_value
FROM extract_values
GROUP BY id;
回复

使用道具 举报

结帖率:100% (5/5)

签到天数: 14 天

发表于 2024-11-14 15:17:28 | 显示全部楼层   北京市北京市
A 名称1 B 1 C 2 D 3 E 4 F 5 G   这个如果是固定长度的话,那就取中间字符,应该有个函数是substring  
回复

使用道具 举报

结帖率:100% (5/5)

签到天数: 14 天

发表于 2024-11-14 15:21:41 | 显示全部楼层   北京市北京市
SELECT      SUM(         CAST(SUBSTRING_INDEX(SUBSTRING_INDEX(SUBSTRING_INDEX(text, 'E ', -1), ' F', 1), ' | ', 1) AS SIGNED)     ) AS total_sum FROM      my_table;
回复

使用道具 举报

结帖率:62% (16/26)

签到天数: 4 天

 楼主| 发表于 2024-11-14 15:41:39 | 显示全部楼层   贵州省贵阳市
1752328925 发表于 2024-11-14 15:21
SELECT      SUM(         CAST(SUBSTRING_INDEX(SUBSTRING_INDEX(SUBSTRING_INDEX(text, 'E ', -1), ' F', ...

我现在就是这样的  但是只能求出第一个条件的合,重复的不行。
回复

使用道具 举报

结帖率:62% (16/26)

签到天数: 4 天

 楼主| 发表于 2024-11-14 15:42:00 | 显示全部楼层   贵州省贵阳市
Doral 发表于 2024-11-14 14:37
WITH RECURSIVE split_segments AS (
    -- Step 1: 初始行分割第一段
    SELECT

我的是5.7的  不支持with
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 793400750,邮箱:wp@125.la
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表