1

目前我在 SQL Server 中完成了一个选择,并且必须对 MySQL 有相同的结果,实现在两者中工作的脚本会更好。脚本下方:

select STUFF( (SELECT ', ' + m_e.NAME + '=' + CAST(v.VALUE AS VARCHAR(MAX)) FROM MMP_USER_METADATA_INSTANCE i
    left outer join MMP_USER_METADATA_INST_VALUE v on (i.id=v.USER_METADATA_INSTANCE_ID)
    left outer join MMP_METADATA_ENTRY m_e on (v.METADATAENTRY_ID=m_e.id)
    WHERE (u.id = i.USER_ID) 
    FOR XML PATH(''),TYPE).value('(./text())[1]','VARCHAR(MAX)')   ,1,2,'') AS 'Campos Adicionais' from mmp_user u

Tables:
MMP_USER_METADATA_INSTANCE,
MMP_USER_METADATA_INST_VALUE,
MMP_METADATA_ENTRY,
MMP_USER.

结果:

<table border="1"><tr BGCOLOR="#CCCCFF"><th>Campos Adicionais</th></tr>
<tr><td>Skype=Testes, Centro de Custo=16, Endereço Bairro=Teste, Endereço Cidade=, Estado Civil=44, Filhos=38, Graduação Curso=, Graduação Faculdade=Teste, Nivel de Idioma Inglês=46, Nivel de Idioma Espanhol=46, Outro Idioma=Teste, Link Linkedin=, Link Facebook=Teste, Esporte=teste, Time de Futebol=teste</td></tr>
</table>
4

1 回答 1

2

在 MySQL 中,你想要这样的东西:

select (SELECT group_concat(m_e.NAME, '=', value separator ',')
        FROM MMP_USER_METADATA_INSTANCE i left outer join
             MMP_USER_METADATA_INST_VALUE v
             on i.id = v.USER_METADATA_INSTANCE_ID left outer join
             MMP_METADATA_ENTRY m_e
             on v.METADATAENTRY_ID = m_e.id
        WHERE u.id = i.USER_ID
       ) `Campos Adicionais`
from mmp_user u;
于 2015-09-16T18:27:53.723 回答