Поиск по сайту:

Один запрос MySQL для объединения строк из многих строк в одну строку и отображения соответствующей суммы идентификатора пользователя в другом столбце?


Для этого вы можете использовать GROUP_CONCAT(). Используйте SUM(), чтобы добавить идентификатор пользователя. Сначала создадим таблицу:

mysql> create table DemoTable1960
   (
   StudentId int,
   StudentName varchar(20)
   );
Query OK, 0 rows affected (0.00 sec)

Вставьте несколько записей в таблицу с помощью команды вставки:

mysql> insert into DemoTable1960 values(100,'Chris');
Query OK, 1 row affected (0.00 sec)
mysql> insert into DemoTable1960 values(101,'Bob');
Query OK, 1 row affected (0.00 sec)
mysql> insert into DemoTable1960 values(102,'David');
Query OK, 1 row affected (0.00 sec)
mysql> insert into DemoTable1960 values(103,'Mike');
Query OK, 1 row affected (0.00 sec)

Отобразите все записи из таблицы с помощью оператора select:

mysql> select * from DemoTable1960;

Это даст следующий результат:

+-----------+-------------+
| StudentId | StudentName |
+-----------+-------------+
|       100 | Chris       |
|       101 | Bob         |
|       102 | David       |
|       103 | Mike        |
+-----------+-------------+
4 rows in set (0.00 sec)

Вот запрос для объединения строк из многих строк в одну, а также для отображения суммы идентификаторов пользователей:

mysql> select sum(StudentId),group_concat(StudentName separator '.') as ListOfStudent from DemoTable1960;

Это даст следующий результат:

+----------------+----------------------+
| sum(StudentId) | ListOfStudent        |
+----------------+----------------------+
|            406 | Chris.Bob.David.Mike |
+----------------+----------------------+
1 row in set (0.00 sec)

Статьи по данной тематике: