日期:2014-05-16 浏览次数:20603 次
mysql怎么合并多条记录的单个字段去一条记录,今天在网上找了一下,方法如下:
?
?
测试用表结构:
-- --------------------
--
-- 表的结构 `tet`
--
CREATE TABLE IF NOT EXISTS `tet` (
? `id` int(11) NOT NULL,
? `name` varchar(255) NOT NULL,
? `url` varchar(255) NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
--
-- 转存表中的数据 `tet`
--
INSERT INTO `tet` (`id`, `name`, `url`) VALUES
(1, '百度
', 'http://www.baidu.com
'),
(0, 'google
', 'http://www.google.com.hk
'),
(3, '400电话
', 'http://www.my400800.cn
');
?
方法一:
SELECT GROUP_CONCAT ( name ) name
FROM tet
WHERE 1 = 1
LIMIT 0 , 30
?
?
结果:
name 百度,google,400电话
?
GROUP_CONCAT还可以用
SEPARATOR? 关键词指定连接符,sql语句如下:
?
SELECT GROUP_CONCAT ( url SEPARATOR " @ " ) url
FROM tet
WHERE 1 = 1
LIMIT 0 , 30
?
?
结果:
http://www.baidu.com@http://www.google.com.hk@http://www.my400800.cn
?
?
?
方法二:
SELECT GROUP_CONCAT ( name ) name
FROM tet
WHERE 1 = 1
GROUP BY id
LIMIT 0 , 30
?
?
结果:
百度 |
400电话 |
?