mysql根据分隔符进行字段拆分

  1. 虽然已经有不少相似的写法,我这里仍是本身写一写,有些分隔符分出的列数是不固定的,这时候怎么根据分隔符拆分出多列呢
insert into tpems.sp_questions_bank (id, title, option_a, option_b, option_c, option_d, option_e, answer1, answer2, parse, qtpye, diff, md5, subjectId, gradeId, knowledges, area, year, paperTpye, source, fromSite, isSub, isNormal, isKonw, tiid, Similarity, isunique, md52, s_type, s_qid, s_pid, s_user_id, s_user_name, s_option_number, s_status, s_create_time, s_last_update_time, s_is_exercise, s_select_number
)
SELECT 
    null,
    t.title,
    IF(t.opi >= 1, t.option_a, '') a,
    IF(t.opi >= 2, t.option_b, '') b,
    IF(t.opi >= 3, t.option_c, '') c,
    IF(t.opi >= 4, t.option_d, '') d,
    IF(t.opi >= 5, t.option_e, '') e,
    t.answer,
    null,
    t.description, 
    t.type,
    null,
    null,
    null,
    null,
    null,
    null,
    null,
    null,
    null,
    null,
    null,
    null,
    null,
    null,
    null,
    null,
    null,
    0,
    t.id,
    t.pid,
    t.user_id,
    t.user_name,
    t.option_number,
    t.status,
    t.create_time,
    t.last_update_time,
    t.is_exercise,
    t.select_number
FROM
    (SELECT 
            sp.id,
            sp.user_id,
            sp.type,
            sp.title,
            sp.user_name,
            sp.option_number,
            sp.answer,
            sp.description,
            sp.status,
            sp.create_time,
            sp.last_update_time,
            sp.is_exercise,
            sp.pid,
            sp.select_number,
            (LENGTH(sp.option) - LENGTH(REPLACE(sp.option, '^^', ''))) / 2 + 1 AS opi,
            if(sp.type in(4,5,6),sp.option,SUBSTRING_INDEX(SUBSTRING_INDEX(sp.option, '^^', 1), '^^', - 1)) AS option_a,
            if(sp.type in(4,5,6),'',SUBSTRING_INDEX(SUBSTRING_INDEX(sp.option, '^^', 2), '^^', - 1)) as option_b,
            if(sp.type in(4,5,6),'',SUBSTRING_INDEX(SUBSTRING_INDEX(sp.option, '^^', 3), '^^', - 1)) as option_c,
            if(sp.type in(4,5,6),'',SUBSTRING_INDEX(SUBSTRING_INDEX(sp.option, '^^', 4), '^^', - 1)) as option_d,
            if(sp.type in(4,5,6),'',SUBSTRING_INDEX(SUBSTRING_INDEX(sp.option, '^^', 5), '^^', - 1)) as option_e
    FROM
        tpems.sp_question sp) t;

首先描述下个人sql的工做场景,有一列数据是用分隔符“^^”进行分隔的,一个字段里的值,而后须要把字段拆开,而后放到不一样的option里面去, option有5个,而后字段里的分隔符的数目也是不固定的。 这里我是肯定了一下最大的上限值,最多只能写5个,而后这样就简单了。sql

(LENGTH(sp.option) - LENGTH(REPLACE(sp.option, '^^', ''))) / 2 + 1 AS opi

肯定了分隔符能够分出的列数。函数

而后判断选项的个数code

IF(t.opi >= 1, t.option_a, '') a,
    IF(t.opi >= 2, t.option_b, '') b,
    IF(t.opi >= 3, t.option_c, '') c,
    IF(t.opi >= 4, t.option_d, '') d,
    IF(t.opi >= 5, t.option_e, '') e,

这里解释下if函数,if(表达式,a,b) 表达式若是为真则返回a,不然返回b 因此这里的判断就是,若是只能分出两个option则,3,4,5的值都是空 ,就成功的将一列值扩充到多列orm

相关文章
相关标签/搜索