用SQL将查询出来的多列的值拼接成一个字符串

来源:互联网 发布:java乱码转换成中文 编辑:程序博客网 时间:2024/06/05 10:28
用SQL将查询出来的多列的值拼接成一个字符串
 
MySQL中:
 
[sql] 
-- 单列拼接,先查出一行,再加上逗号,接着拼接 查出的下一行  
select group_concat(E.SUPPORT)  
from ENGINES E  
where E.XA IN('YES','NO')  
--结果如下:YES,YES,YES,YES,YES,YES,DEFAULT,YES  
  
-- 将查询的结果中的 "," 号,替换成 "**" 号   
select REPLACE(group_concat(E.SUPPORT),',','**')  
from ENGINES E  
where E.XA IN('YES','NO')  
--结果如下:YES**YES**YES**YES**YES**YES**DEFAULT**YES  
  
-- 将查询的结果中 重复 的记录 去掉,只剩一条记录,然后再拼接  
select group_concat(DISTINCT(E.SUPPORT))  
from ENGINES E  
where E.XA IN('YES','NO')  
--结果如下:YES,DEFAULT  
  
-- 多列拼接,同一行的先拼接,再加上逗号,接着拼接下一行  
select group_concat(E.ENGINE,E.SUPPORT)  
from ENGINES E  
where E.XA IN('YES','NO')  
--结果如下:MRG_MYISAMYES,MyISAMYES,BLACKHOLEYES,CSVYES,MEMORYYES,ARCHIVEYES,InnoDBDEFAULT,PERFORMANCE_SCHEMAYES  
 
0 0