ホームページ > データベース > mysql チュートリアル > MySQL で名前文字列から名、ミドルネーム、姓を抽出するにはどうすればよいですか?

MySQL で名前文字列から名、ミドルネーム、姓を抽出するにはどうすればよいですか?

Susan Sarandon
リリース: 2025-01-19 15:48:16
オリジナル
382 人が閲覧しました

How to Extract First, Middle, and Last Names from a Name String in MySQL?

MySQL の名前文字列から名、ミドルネーム、姓を抽出します

名前文字列をその構成部分 (名、ミドルネーム、姓) に分割することは、データ処理において便利なタスクです。 MySQL では、これを実現するためにいくつかの方法を使用できます。

方法 1 (名、ミドルネーム、姓)

この方法では、SUBSTRING_INDEX() 関数と IF() 関数を組み合わせて使用​​して、個々の名前を抽出します。

<code class="language-sql">SELECT
   SUBSTRING_INDEX(SUBSTRING_INDEX(fullname, ' ', 1), ' ', -1) AS first_name,
   IF(LENGTH(fullname) - LENGTH(REPLACE(fullname, ' ', '')) > 1,
       SUBSTRING_INDEX(SUBSTRING_INDEX(fullname, ' ', 2), ' ', -1), NULL) AS middle_name,
   SUBSTRING_INDEX(SUBSTRING_INDEX(fullname, ' ', 3), ' ', -1) AS last_name
FROM registeredusers;</code>
ログイン後にコピー

このクエリ内:

  • SUBSTRING_INDEX(SUBSTRING_INDEX(fullname, ' ', 1), ' ', -1) 名前を抽出します。
  • IF(LENGTH(fullname) - LENGTH(REPLACE(fullname, ' ', '')) > 1, SUBSTRING_INDEX(SUBSTRING_INDEX(fullname, ' ', 2), ' ', -1), NULL) ミドルネームが存在するかどうかを確認し、存在する場合は抽出します。存在しない場合、ミドルネームは NULL に設定されます。
  • SUBSTRING_INDEX(SUBSTRING_INDEX(fullname, ' ', 3), ' ', -1) 姓を抽出します。

方法 2 (名、姓)

姓名のみに興味がある場合は、LOCATE() 関数と TRIM() 関数を使用する簡単なクエリを使用できます。

<code class="language-sql">SELECT
   SUBSTRING_INDEX(SUBSTRING_INDEX(fullname, ' ', 1), ' ', -1) AS first_name,
   TRIM(SUBSTR(fullname, LOCATE(' ', fullname))) AS last_name
FROM registeredusers;</code>
ログイン後にコピー

このクエリ内:

  • SUBSTRING_INDEX(SUBSTRING_INDEX(fullname, ' ', 1), ' ', -1) 名前を抽出します。
  • TRIM(SUBSTR(fullname, LOCATE(' ', fullname))) は名前の最初のスペース以降の部分を抽出し、実質的に姓を取得します。

以上がMySQL で名前文字列から名、ミドルネーム、姓を抽出するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート