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

MySQL中:

[sql] view plaincopyprint?
-- 单列拼接,先查出一行,再加上逗号,接着拼接 查出的下一行  
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  

 

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。