ホームページ >データベース >mysql チュートリアル >mysqlのfind_in_set文字列検索関数の解析

mysqlのfind_in_set文字列検索関数の解析

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB転載
2022-08-29 11:45:302435ブラウズ

推奨される学習: mysql ビデオ チュートリアル

要件

システム内で、それが注文であろうと、返品注文。一部のプラットフォームでは販売者のレビューが必要ですが、その他のプラットフォームでは必要がないため、システムで注文または返品のプロセス ノードを設定できます。

各プロセス ノードについて、顧客の要件は、注文を組織の従業員が処理するのではなく、個人に割り当てることができるように、システム内の従業員の役割に従って各ノードを分散する必要があることです。会社全体。

計画

上記のシナリオの場合、私が実装した解決策は、対応するノードの処理対象フィールドを注文テーブルと返品注文テーブルの両方に追加することです。複数人で処理できる場合は、対応する従業員の ID コレクションを分離して保存します。

したがって、注文のクエリ方法にも対応する変更を加える必要があり、誰もが自分が処理できる注文のみを表示できます。

テーブルのサンプルコンテンツは次のとおりです:

従業員がシステムにログインすると、対応するデータを取得できます。 ID がビジネス レビュー、財務レビュー、または荷主コレクションに含まれているかどうかを確認するには、対応するフィールドで ID を検索する必要があります。このとき、SQLをどのように変更すればよいのでしょうか?

関数

SQL を変更する前に、MYSQL の多くの関数が以前にまとめられていると思いました。上記の実装については、それを実現するのに役立つ対応する関数が MYSQL に必ず存在します。案の定、見つけました。

1. はじめに

MySQL には FIND_IN_SET() という組み込みの文字列関数が用意されており、これを使用すると、カンマ区切りの文字列リスト内で指定された文字列の位置を見つけることができます。

2. 構文: FIND_IN_SET(needle,haystack)

FIND_IN_SET() 関数は 2 つのパラメータを受け入れます:

  • needle は検索する文字列です。
  • haystack は、検索する文字列のカンマ区切りリストです。

FIND_IN_SET() 関数は、パラメータの値に基づいて整数または NULL 値を返します。

  • 針または干し草の山が NULL の場合の場合、関数は NULL 値を返します。
  • 針が干し草の山にない場合、または干し草の山が空の文字列の場合は、ゼロが返されます。
  • 針が干し草の山にある場合は、正の整数を返します。

3. 実践的な実践

以下は、プロジェクト内の番号 8910 の従業員が処理できる、ビジネス レビュー保留中の注文の SQL です。結果は次のとおりです。

上の結果のスクリーンショットでは、ID 6594、6523、および 6373 で囲まれた 3 つの注文は、従業員番号 8910 によってのみ処理できます。上記の SQL 従業員番号を 8912 にすると、これら 3 つの注文は結果範囲内に含まれないため、この関数を使用してクエリを実行できるかどうかが検証されます。

クエリ結果は次のとおりです。

結果は、クエリに問題がないことを示しています。

Interlude

2 日前、同僚がグループにスクリーンショットを投稿し、次のような質問をしました:

簡単な説明:

画像アドレス列には古いデータ センターのアドレスが格納されています。新しいデータ センターがオンラインになったので、画像を取得するには新しいアドレスに置き換える必要があります。

これを読んだ後、以前に使用した、文字列を置換できる MYSQL の REPLACE() 関数のことを思い出しました。したがって、更新ステートメントは次のようになります:

SELECT
	t.id_,t.order_sn,t.create_time, t.business_employee_ids,cus.customer_title
FROM
	wms_orders t
LEFT JOIN wms_customer cus ON cus.id = t.buyer_id
WHERE
	t.order_status != 100
AND t.comp_id = 8815
AND FIND_IN_SET(
	'8910',
	t.business_employee_ids
)
AND t.order_status = 14
AND (
	t.parent_order_sn IS NULL
	OR t.parent_order_sn = ''
)
ORDER BY
	t.id_ DESC

推奨される学習:

mysql ビデオ チュートリアル

以上がmysqlのfind_in_set文字列検索関数の解析の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はjb51.netで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。