ホームページ > データベース > mysql チュートリアル > 動的 Case ステートメントの入力文字列を効率的に分割して使用する方法

動的 Case ステートメントの入力文字列を効率的に分割して使用する方法

Susan Sarandon
リリース: 2024-12-31 19:45:18
オリジナル
910 人が閲覧しました

How to Efficiently Split and Use Input Strings for Dynamic Case Statements?

入力文字列の分割

入力文字列 (日付とセット) を分割するには、次の手法を使用できます。

  1. 日付(p_dates): string_to_array() 関数を使用して、日付文字列から日付範囲の配列を作成します。例:

    SELECT string_to_array('2001-01-01to2001-01-05,2001-01-10to2001-01-15', ',')
    ログイン後にコピー
  2. Sets (p_sets): 同様に、string_to_array() 関数を使用して、set 文字列をセット名の配列に分割します。例:

    SELECT string_to_array('s1,s2,s3,s4', ',')
    ログイン後にコピー

動的 Case ステートメントの準備

これらの配列が作成されたら、それらを使用して動的 Case ステートメントを生成できます。 CASE WHEN ステートメントと SELECT ステートメントを組み合わせて使用​​します。例:

CASE WHEN given_dates BETWEEN date_ranges[1] AND date_ranges[2] THEN set_names[1]
     WHEN given_dates BETWEEN date_ranges[3] AND date_ranges[4] THEN set_names[2]
     ...
     ELSE NULL
END
ログイン後にコピー

ここで、date_ranges と set_names は、それぞれ p_dates と p_sets から作成された配列です。

この動的 case ステートメントを使用して、指定された内容に基づいて set_name 列を更新できます。日付範囲とセット名。

以上が動的 Case ステートメントの入力文字列を効率的に分割して使用する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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