MySQL
 Computer >> コンピューター >  >> プログラミング >> MySQL

MySQLに番号付けを実装するGROUP_CONCAT


まずテーブルを作成しましょう-

mysql> create table DemoTable1627
    -> (
    -> FirstName varchar(20),
    -> LastName varchar(20)
    -> );
Query OK, 0 rows affected (0.59 sec)

挿入コマンドを使用して、テーブルにいくつかのレコードを挿入します。

mysql> insert into DemoTable1627 values('John','Smith');
Query OK, 1 row affected (0.11 sec)
mysql> insert into DemoTable1627 values('John','Doe');
Query OK, 1 row affected (0.13 sec)
mysql> insert into DemoTable1627 values('Adam','Smith');
Query OK, 1 row affected (0.18 sec)
mysql> insert into DemoTable1627 values('Carol','Taylor');
Query OK, 1 row affected (0.08 sec)

selectステートメントを使用してテーブルのすべてのレコードを表示する-

mysql> select * from DemoTable1627;

これにより、次の出力が生成されます-

+-----------+----------+
| FirstName | LastName |
+-----------+----------+
| John      | Smith    |
| John      | Doe      |
| Adam      | Smith    |
| Carol     | Taylor   |
+-----------+----------+
4 rows in set (0.00 sec)

group_concat()の番号付けを実装するためのクエリは次のとおりです-

mysql> select  LastName,
    -> group_concat(
    -> concat(@j := if (@p = LastName, @j + 1, if(@p := LastName,1,1)), '.', FirstName)
    -> separator ', ') FirstName
    -> from   DemoTable1627
    -> group by LastName;

これにより、次の出力が生成されます-

+----------+----------------+
| LastName | FirstName      |
+----------+----------------+
| Doe      | 1.John         |
| Smith    | 1.John, 2.Adam |
| Taylor   | 1.Carol        |
+----------+----------------+
3 rows in set (0.09 sec)

  1. MySQLに調和平均と二次平均を実装しますか?

    まずテーブルを作成しましょう- mysql> create table DemoTable1606    -> (    -> Value int    -> ); Query OK, 0 rows affected (0.55 sec) 挿入コマンド-を使用して、テーブルにいくつかのレコードを挿入します mysql> insert into DemoTable1606 values(5); Query OK, 1 row affected (0.10 sec) mysql> insert int

  2. MySQLでDOUBLEの長さを実装および設定する

    MySQLでDOUBLEを実装するための構文は、次のとおりです- create table yourTableName      (      yourColumnName double(5,2) unsigned );を作成します まずテーブルを作成しましょう- mysql> create table DemoTable1814      (      Amount double(5,2) unsigned      ); Query