mysqlでin operatorを使用する方法は?
MySQLのオペレーターは、値が指定されたリストの任意のものと一致し、複数または条件を簡素化するかどうかをチェックします。リテラル、文字列、日付、およびサブクエリで動作し、クエリの読みやすさを向上させ、インデックス付きの列でうまく機能し、サポートしない(ヌルには注意が払われている)、他の条件と組み合わせることができ、SQLクエリでの効率的なフィルタリングに不可欠です。
MySQLのIN
オペレーターは、値がリストの任意の値と一致するかどうかを確認するために使用されます。 WHERE
句の複数OR
条件を交換するのに便利な方法です。効果的に使用する方法は次のとおりです。
基本的な構文
column_name(s)を選択します Table_nameから column_name in(value1、value2、...);
これは次のとおりです。
column_name = value1またはcolumn_name = value2または...
1。値のリストを使用したフィルタリング
列がいくつかの指定された値のいずれかと一致するIN
を取得するために使用できます。
[従業員から]を選択します ここで、(1、3、5)in department_id;
これにより、部門1、3、または5の部門で働くすべての従業員が選択されます。これは、3つの別々 OR
条件を書くよりもはるかにクリーンです。
2。文字列と日付を使用します
IN
オペレーターは、文字列や日付を含む任意のデータタイプで動作します。
[顧客から]を選択します 国(「アメリカ」、「カナダ」、「メキシコ」)の国;
select * from注文 WHERE ORDER_DATE IN( '2023-09-01'、 '2023-09-02'、 '2023-09-03');
文字列と日付の値に見積もりを使用してください。
3.値を除外するために使用しない
リスト内の値と一致しないレコードを見つけるには、 NOT IN
使用します。
[from製品]を選択します Category_id in(2、4);
これにより、カテゴリ2または4にない製品が返されます。
⚠リスト
NOT IN
は、リストにNULL
が含まれている場合に注意してください。IN
リストにある値がNULL
である場合、NULL
との比較はSQLロジックではNOT IN
UNKNOWN
ため、結果は返されません。
4。inでサブ征服を使用します
IN
の最も強力な用途の1つは、サブクエリを使用することです。
[顧客から]を選択します customer_id in(1000> 1000の注文からcustomer_idを選択);
これにより、少なくとも1つの注文を1000ドル以上にしたすべての顧客が見つかります。
サブクエリは最初に実行され、顧客IDのリストを返し、外部クエリはそれらを一致させるためにIN
します。
覚えておくべき重要なポイント
IN
オペレーターは、複数OR
条件と比較して、読みやすさを向上させ、コードの長さを削減します。- これは、ほとんどのMySQL照合(
utf8mb4_general_ci
など)の文字列の場合は症例に依存しませんが、これは列の照合設定に依存します。 - 特に列がインデックス化されている場合、パフォーマンスは一般的に良好です。非常に大きなリストについては、一時テーブルの使用または
JOIN
を検討してください。 -
NULL
を返す可能性のあるヌル可能な列やサブクリーリーでNOT IN
てください。そのような場合は、より安全な結果を得るために代わりにNOT EXISTS
。
例:他の条件と組み合わせる
名前、従業員からの給与を選択します (1、2)のdepartment_id 給与> 50000;
これは、50,000ドル以上を稼ぐ部門1または2の従業員を示しています。
基本的に、文字通りの値であろうとサブクエリからの一連の値でフィルタリングをIN
化し、毎日のMySQLクエリの定番です。
以上がmysqlでin operatorを使用する方法は?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undress AI Tool
脱衣画像を無料で

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

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

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

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

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

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

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

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

MySQLは、バージョン8.0.16から効果的なドメインの完全性を強制するためのチェック制約をサポートしています。 1.テーブルを作成するときに制約を追加する:createTableを使用して、18歳以上、給与> 0、部門の制限値などのチェック条件を定義します。 2。テーブルを変更して制約を追加します。AlterTableadDconstraintを使用して、名前以外の名前などのフィールド値を制限します。 3.複雑な条件を使用する:終了日≥の日付や完了ステータスなどのマルチカラムロジックと式のサポートは、終了日を持つ必要があります。 4。制約の削除:AlterTabledRopConstraintを使用して、削除する名前を指定します。 5。注:mysql8.0.16、innodbまたはmyisamを引用する必要があります

MySQLにすべてのデータベースを表示するには、ShowDataBaseコマンドを使用する必要があります。 1.MySQLサーバーにログインした後、ShowDatabaseを実行できます。現在のユーザーがアクセスする許可があるすべてのデータベースをリストするコマンド。 2。information_schema、mysql、performance_schema、sysなどのシステムデータベースはデフォルトで存在しますが、許可が不十分なユーザーはそれを見ることができない場合があります。 3. selectschema_namefrominformation_schema.schemataを介してデータベースをクエリしてフィルタリングすることもできます。たとえば、システムデータベースを除外して、ユーザーが作成したデータベースのみを表示します。必ず使用してください

既存のテーブルにプライマリキーを追加するには、AddPrimaryKey句を使用してAlterTableステートメントを使用してください。 1.ターゲット列にヌル値も重複もなく、notnullと定義されていることを確認してください。 2.単一列のプライマリキー構文は、変更可能なテーブル名AddPrimaryKey(列名)です。 3.マルチカラムの組み合わせプライマリキー構文は、変更可能なテーブル名AddPrimaryKeyです(列1、列2)。 4.列がnullを許可する場合、最初に変更を実行してnotnullを設定する必要があります。 5.各テーブルには1つの主キーのみがあり、追加する前に古いプライマリキーを削除する必要があります。 6.自分で増やす必要がある場合は、Modifyを使用してAuto_incrementを設定できます。操作前にデータを確認してください

MySQLサービスが実行されているかどうかを確認して、sudosystemctlstatusmysqlを使用して確認および開始します。 2.リモート接続を許可してサービスを再起動するために、バインドアドレスが0.0.0.0に設定されていることを確認してください。 3. 3306ポートが開いているかどうかを確認し、ポートを許可するファイアウォールルールを確認して構成します。 4。「アクセス」エラーの場合、ユーザー名、パスワード、ホスト名を確認し、mysqlにログインしてmysql.userテーブルをクエリしてアクセス許可を確認する必要があります。必要に応じて、 'your_user'@'%'を使用するなど、ユーザーを作成または更新して承認します。 5. caching_sha2_passwordにより認証が失われた場合

MySQLDUMPを使用することは、MySQLデータベースをバックアップする最も一般的で効果的な方法です。テーブル構造とデータを含むSQLスクリプトを生成できます。 1.基本的な構文は、mysqldump-u [ユーザー名] -p [データベース名]> backup_file.sqlです。実行後、パスワードを入力してバックアップファイルを生成します。 2。-DATABASESオプションを使用して複数のデータベースをバックアップします:mysqldump-uroot-p--databasedb1db2> multive_dbs_backup.sql。 3.すべてのデータベースをバックアップしてください-all-database:mysqldump-uroot-p

tooptimizemysqlperformance foracrmsystem、focusonindexingstrategies、schemadesignbalance、and queryeffisity.1)usepererindexingingbyanalyzingingfhereclausecolumns、jockeys、andordexeffield、およびconsonderingindexingsonsonwhereclausecolumns、and consinderingindexesonsonwhereclausecolumns、addexesonsonwhereclausecolumns、

b-TreeindexeSareBestformostphpapplications、astheisupportequalityandrangequeries、sorting、andareidealforumnsuseduseduseduseduseduseduseduseds; ororderbyclauses;

UnionRemovesDulisionallkeepsallowsincludingDuplicates;
