case when文のエラー問題の詳細な説明

case when文のエラー問題の詳細な説明

序文

MySQL データベースでは、if else のような判断演算を使用することがあります。では、MySQL でこの要件をどのように処理すればよいのでしょうか?

mysql 判定操作構文:

case ..when 文

しかし、最近使用中に問題が発生しました。以下では多くは述べません。詳細な紹介を見てみましょう。

問題を直接述べます。 ID 番号を格納するテーブル id_card_message があります。テーブル構造とデータは次のとおりです (MySQL 5.7.14):

mysql> id_card_message から * を選択します。

+------+--------------------+

| ID | IDカード番号 |

+------+--------------------+

| 1 | 342513199411222515 |

| 1 | 342624197812023498 |

| 1 | 310908198910123348 |

+------+--------------------+

ここで、ID カード番号の最後から 2 番目の桁に基づいて性別情報を表示したいと思います。次の SQL ステートメントを実行すると、対応するエラーが報告されます。

mysql> ケース substr(id_card_no,17,1) を選択

-> (1,3,5,7,9) の場合、「男」

-> (0,2,4,6,8) の場合、「女」は「セックス」を終了します。

-> IDカード番号

-> id_card_message から;

エラー 1241 (21000): オペランドには 1 列が必要です

エラーには次のように表示されます:オペランドには 1 つの列が含まれている必要があります。ここでの唯一の疑いは、when 節の後の括弧内に値が多すぎることです。この場合、when 構造では、when 節の後には 1 つの値しか出現できないのでしょうか?以下の公式ドキュメントのセクション 13.6.5.1 の case 構文を確認しましたが、これについては説明がないようです。

もちろん、ステートメントの形式を変更することで、必要なデータを取得することもできます。次のように:

mysql>選択

-> ケース

-> substr(id_card_no,17,1) が (1,3,5,7,9) の場合、 '男'

-> substr(id_card_no,17,1) が (0,2,4,6,8) 内にある場合、'女' は 'sex' となります。

-> IDカード番号

-> id_card_message から;

+------+--------------------+

| 性別 | IDカード番号 |

+------+--------------------+

| 男性 | 342623199610222515 |

| 男性 | 342624197812023498 |

| 女性 | 310908198910123348 |

+------+--------------------+

現在の考え方では、「CASE 値 WHEN 比較値」の形式では、when 句の後の比較値は単一の値のみであり、複数の値に接続することはできません。たとえば、上記の比較値には 1、3、5、7、9 という値があります。この場合、上記の SQL のみ使用できます。

要約する

上記はこの記事の全内容です。この記事の内容が皆さんの勉強や仕事に一定の参考学習価値を持つことを願っています。ご質問があれば、メッセージを残してコミュニケーションしてください。123WORDPRESS.COM を応援していただきありがとうございます。

以下もご興味があるかもしれません:
  • MySQL CASE WHEN ステートメントの使用手順
  • SQL 集計関数で case when then を使用する際のヒント
  • SQL 学習: CASE WHEN THEN ELSE END の使い方
  • MySQLのCASE WHEN文の使用例をいくつか紹介します。
  • MySQL で case when 文を使用して複数条件クエリを実装する方法
  • SQL で case when 構文を使用する方法
  • SQL ステートメントの行と列の変換の 2 つの方法の簡単な分析: ケース... 場合とピボット関数の適用
  • 合計(場合によります)(男子生徒と女子生徒の数を決定する)
  • MySQL のグループ分けの例
  • MySQLソートにおけるCASE WHENの使用例

<<:  Vuex データの永続性を実装するためのアイデアとコード

>>:  Tomcatの自動シャットダウンに関するバグ修正

推薦する

Webフロントエンドインターフェースの設計に必須のスキル

[必須] ユーザーインターフェースPhotoShop/花火デザインアーティストと協力して、スケッチを...

ウェブページでコンテンツを引用するためによく使われるHTMLタグをマスターする

長い引用には blockquote を、短い引用には q を、参考文献には cite を使用します。...

プレーヤー機能を実現するためのvue + element uiのサンプルコード

効果画像のない表示は単なる空虚な言葉です。 1. オーディオをベースにし、elementUI と組み...

Dockerリンクはコンテナの相互接続を実現します

目次1.1. IP経由のコンテナ間のネットワークアクセス1.2. コンテナ名またはコンテナIDによる...

meta name="" content="の機能の詳細な説明

1. 文法: <meta name="名前" content="...

nginx リバース プロキシでの proxy_pass の実装

フォーマットはシンプルです: proxy_pass URL; URL には、送信プロトコル (htt...

JS クロスドメイン XML - AS URLLoader を使用

最近、機能拡張の要件を受け取りました。ただし、新しい要件で参照されているデータインターフェイスは、X...

HTML におけるメタの役割について (インターネットから収集および分類)

W3Cschoolではこのように説明しています<meta> 要素は、検索エンジン向けの説...

SpringBoot のパッケージ化と Docker へのアップロード、およびマルチインスタンス デプロイメントの実装に関する簡単な分析 (IDEA バージョン)

最近友人からDockerを触ったことがあるかと聞かれました。あまり自信がなかったので答えられませんで...

Mybatis mysqlの削除操作では、最初のデータメソッドのみを削除できます。

バグ図のように、削除文とパラメータをデータベースにコピーして実行し、2つのデータを削除しようとしたの...

ウェブ クラスターの Docker Stack 展開方法の手順

Docker はますます成熟し、その機能もますます強力になっています。 Docker Stack を...

Docker イメージのエクスポート、インポート、コピーの例の分析

最初の解決策は、イメージを公開イメージリポジトリにプッシュし、それをプルダウンすることです。 2 番...

JavaScript 関数をよりエレガントにする方法

目次分割代入を使用したオブジェクトパラメータコールバック関数の命名条件文を説明的にするスイッチ文をM...

CSSセレクターでの正規表現の使用

はい、CSS にも正規表現があります (アーメン) CSS で目立つための 2 つの強力なツール: ...

Vue ログインページでクッキーを使用してパスワードを 7 日間記憶する方法

問題の説明プロジェクトのログインページでは、7日間パスワードを記憶する必要がある機能があります。この...