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

MySQLクエリで列の値から最初の単語だけを削除するにはどうすればよいですか?


列の値から最初の単語のみを削除するには、substring()を使用します。以下は構文です-

select substring(yourColumnName,locate(' ',yourColumnName)+1) AS anyAliasName from yourTableName;

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

mysql> create table DemoTable
(
   Title text
);
Query OK, 0 rows affected (0.50 sec)

挿入コマンド-

を使用して、テーブルにいくつかのレコードを挿入します
mysql> insert into DemoTable values('Java in Depth');
Query OK, 1 row affected (0.49 sec)
mysql> insert into DemoTable values('C++ is an object oriented programming language');
Query OK, 1 row affected (0.47 sec)
mysql> insert into DemoTable values('MySQL is a relational database');
Query OK, 1 row affected (0.17 sec)
mysql> insert into DemoTable values('Python with data structure');
Query OK, 1 row affected (0.24 sec)

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

mysql> select *from DemoTable;

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

+------------------------------------------------+
| Title                                          |
+------------------------------------------------+
| Java in Depth                                  |
| C++ is an object oriented programming language |
| MySQL is a relational database                 |
| Python with data structure                     |
+------------------------------------------------+
4 rows in set (0.00 sec)

以下は、列の値から最初の単語を削除するためのクエリです-

mysql> select substring(Title,locate(' ',Title)+1) AS RemoveFirstWord from DemoTable;

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

+--------------------------------------------+
| RemoveFirstWord                            |
+--------------------------------------------+
| in Depth                                   |
| is an object oriented programming language |
| is a relational database                   |
| with data structure                        |
+--------------------------------------------+
4 rows in set (0.00 sec)

  1. 5つの値を持つ列から最初の3つの値のみの平均を見つけるMySQLクエリ

    このために、サブクエリを使用できます。まずテーブルを作成しましょう- mysql> create table DemoTable (    Score int ); Query OK, 0 rows affected (0.62 sec) 挿入コマンド-を使用して、テーブルにいくつかのレコードを挿入します mysql> insert into DemoTable values(80); Query OK, 1 row affected (0.13 sec) mysql> insert into DemoTable values(45); Query OK

  2. 対応する列の値からNO値のみのカウントを返すMySQLクエリ

    まずテーブルを作成しましょう- mysql> create table DemoTable1829      (      Name varchar(20),      isTopper ENUM('YES','NO')      ); Query OK, 0 rows affected (0.00 sec) 挿入コマンド-を使用して、テーブルにいくつかのレコードを挿入します mysql> insert into DemoTabl