php - 如何从多行中选择并连接列值?

标签 php mysql

我有下表:

CREATE TABLE IF NOT EXISTS `article` (
  `article_id` int(11) NOT NULL,
  `language_id` int(11) NOT NULL,
  `category_id` int(11) NOT NULL,
  `article_title` varchar(100) CHARACTER SET utf8 COLLATE utf8_bin NOT NULL,
  `article_body` varchar(8192) CHARACTER SET utf8 COLLATE utf8_bin NOT NULL,
  `meta_description` varchar(255) CHARACTER SET utf8 COLLATE utf8_bin NOT NULL,
  `meta_keyword` varchar(255) CHARACTER SET utf8 COLLATE utf8_bin NOT NULL,
  `article_main_image` varchar(255) CHARACTER SET utf8 COLLATE utf8_bin NOT NULL,
  `promote` bit(1) NOT NULL DEFAULT b'0',
  `created` datetime NOT NULL,
  `modified` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  `deleted` bit(1) NOT NULL DEFAULT b'0',
  `published` bit(1) NOT NULL DEFAULT b'1',
  `user_id` int(11) NOT NULL,
  PRIMARY KEY (`article_id`,`language_id`),
  KEY `article_title` (`article_title`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;

lagnuage_id:

英语 = 1

阿拉伯语 = 2

俄语 = 3

我想选择 * where language_id = 1 limit by 10,但如果语言列具有相同的 article_id,则将它们合并为一个。例如:

(1, 1, 0, 'qwq', 'da sdsad as da ds', 'asd sa d', 'as dsadasd as d sa', '', b'0', '2013-06-20 11:01:32', '2013-06-20 08:01:32', b'0', b'1', 0),
(1, 2, 0, '????????', '?? ??? ??? ??? ???', '?? ??? ??? ? ???? ', '??? ??? ?? ???? ?? ???? ', '', b'0', '2013-06-20 11:01:32', '2013-06-20 08:01:32', b'0', b'1', 0),
(1, 3, 0, 'rrrrrrrrrrr', 'rrrr', 'rrrrrrrrrrrrrrrrr', 'rrrrrrrrrrrrrrrrrrrrrrrrrr', '', b'0', '2013-06-20 11:01:32', '2013-06-20 08:01:32', b'0', b'1', 0),

我想选择这样的行:

(1, 1-2-3, 0, 'qwq', 'da sdsad as da ds', 'asd sa d', 'as dsadasd as d sa', '', b'0', '2013-06-20 11:01:32', '2013-06-20 08:01:32', b'0', b'1', 0),

注意语言 ID 是如何连接的;我想知道本文可以使用哪些语言。

最佳答案

使用 GROUP BYGROUP_CONCAT 我能够解决我的问题:

SELECT  `article_id` , GROUP_CONCAT(  `language_id` ) , ..,..,..,..
FROM  `article` 
GROUP BY  `article_id` 
LIMIT 0 , 30

关于php - 如何从多行中选择并连接列值?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17274335/

相关文章:

php - 从数组中获取特定项目

php - 使用 PHP 进行慢速 solr 索引

php - 使用 foreach 将元素数组放在正确的标题下

mysql - 无法在 SQL 中显示正确的列表

java - 如何在 Oracle Sql Developer 中设置 Jdbc 路径?

php - 如何显示日期小于x时间的行

php - 通过浏览器使用 PDO 将 MySQL 表中的数据存储为 CSV

php - 从 SHOW COLUMNS mysql 中排除某些列

php - 为什么我的数组只返回循环中的最后一个值?

mysql - 使用 SQL 查询计算每一天