mysqlのfind_in_set文字列検索関数の解析
推奨される学習: 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 サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









MySQLは、インストールが簡単で、強力で管理しやすいため、初心者に適しています。 1.さまざまなオペレーティングシステムに適した、単純なインストールと構成。 2。データベースとテーブルの作成、挿入、クエリ、更新、削除などの基本操作をサポートします。 3.参加オペレーションやサブクエリなどの高度な機能を提供します。 4.インデックス、クエリの最適化、テーブルパーティション化により、パフォーマンスを改善できます。 5。データのセキュリティと一貫性を確保するために、バックアップ、リカバリ、セキュリティ対策をサポートします。

次の手順でphpmyadminを開くことができます。1。ウェブサイトコントロールパネルにログインします。 2。phpmyadminアイコンを見つけてクリックします。 3。MySQL資格情報を入力します。 4.「ログイン」をクリックします。

MySQLは、オープンソースのリレーショナルデータベース管理システムです。 1)データベースとテーブルの作成:createdatabaseおよびcreateTableコマンドを使用します。 2)基本操作:挿入、更新、削除、選択。 3)高度な操作:参加、サブクエリ、トランザクション処理。 4)デバッグスキル:構文、データ型、およびアクセス許可を確認します。 5)最適化の提案:インデックスを使用し、選択*を避け、トランザクションを使用します。

MySQLとSQLは、開発者にとって不可欠なスキルです。 1.MYSQLはオープンソースのリレーショナルデータベース管理システムであり、SQLはデータベースの管理と操作に使用される標準言語です。 2.MYSQLは、効率的なデータストレージと検索機能を介して複数のストレージエンジンをサポートし、SQLは簡単なステートメントを通じて複雑なデータ操作を完了します。 3.使用の例には、条件によるフィルタリングやソートなどの基本的なクエリと高度なクエリが含まれます。 4.一般的なエラーには、SQLステートメントをチェックして説明コマンドを使用することで最適化できる構文エラーとパフォーマンスの問題が含まれます。 5.パフォーマンス最適化手法には、インデックスの使用、フルテーブルスキャンの回避、参加操作の最適化、コードの読み取り可能性の向上が含まれます。

NAVICATプレミアムを使用してデータベースを作成します。データベースサーバーに接続し、接続パラメーターを入力します。サーバーを右クリックして、[データベースの作成]を選択します。新しいデータベースの名前と指定された文字セットと照合を入力します。新しいデータベースに接続し、オブジェクトブラウザにテーブルを作成します。テーブルを右クリックして、データを挿入してデータを挿入します。

手順に従って、NAVICATで新しいMySQL接続を作成できます。アプリケーションを開き、新しい接続(CTRL N)を選択します。接続タイプとして「mysql」を選択します。ホスト名/IPアドレス、ポート、ユーザー名、およびパスワードを入力します。 (オプション)Advanced Optionsを構成します。接続を保存して、接続名を入力します。

NAVICATでSQLを実行する手順:データベースに接続します。 SQLエディターウィンドウを作成します。 SQLクエリまたはスクリプトを書きます。 [実行]ボタンをクリックして、クエリまたはスクリプトを実行します。結果を表示します(クエリが実行された場合)。

データベースに接続するときの一般的なエラーとソリューション:ユーザー名またはパスワード(エラー1045)ファイアウォールブロック接続(エラー2003)接続タイムアウト(エラー10060)ソケット接続を使用できません(エラー1042)SSL接続エラー(エラー10055)接続の試みが多すぎると、ホストがブロックされます(エラー1129)データベースは存在しません(エラー1049)
