ホームページ >データベース >mysql チュートリアル >mysqlにネストされたクエリステートメントはありますか?

mysqlにネストされたクエリステートメントはありますか?

WBOY
WBOYオリジナル
2022-05-27 15:12:332388ブラウズ

mysql にはネストされたクエリ ステートメントがあり、その構文は「SELECT ステートメント WHERE 条件 (SELECT ステートメント)」です。このステートメントはサブクエリ ステートメントとも呼ばれ、既存のクエリ ステートメントの where の後にネストできます。クエリ ステートメントの層。つまり、内部クエリの結果を外部クエリによって参照されるデータとして使用します。

mysqlにネストされたクエリステートメントはありますか?

このチュートリアルの動作環境: Windows10 システム、mysql8.0.22 バージョン、Dell G3 コンピューター。

mysql にネストされたクエリ文はありますか?

ネストされたクエリはサブクエリとも呼ばれ、実際の作業でよく使用されるクエリ方法です。サブクエリは実際には、既存のクエリ ステートメントの where の後にネストされたクエリ ステートメントの層です。つまり、内部クエリの結果が外部クエリによって参照されるデータ テーブルとして使用されます。

仕事では、比較演算子 (>、>=、

# 创建学员信息表 
CREATE TABLE stu_info
(
id INT AUTO_INCREMENT PRIMARY KEY, 
iname VARCHAR(20), 
gender CHAR(1), 
department VARCHAR(10), 
age TINYINT, 
province VARCHAR(10), 
email VARCHAR(50), 
mobilephone CHAR(11)
);
# 向学员表中插入数据 
INSERT INTO stu_info(iname,gender,department,age,province,email,mobilephone) VALUES 
('张勇','男','数学系',23,'河南','sfddf123dd@163.com','13323564321'), 
('王兵','男','数学系',25,'江苏','lss1993@163.com','17823774329'), 
('刘伟','男','计算机系',21,'江苏','qawsed112@126.com','13834892240'), 
('张峰','男','管理系',22,'上海','102945328@qq.com','13923654481'), 
('董敏','女','生物系',22,'浙江','82378339@qq.com','13428439022'), 
('徐晓红','女','计算机系',24,'浙江','xixiaohong@gmail.com','13720097528'), 
('赵伊美','女','数学系',21,'江苏','zhaomeimei@163.com','13417723980'), 
('王建国','男','管理系',24,'浙江','9213228402@qq.com','13768329901'), 
('刘清','女','统计系',23,'安徽','lq1128@gmail.com','17823651180'), 
('赵家和','男','计算机系',28,'山东','dcrzdbjh@163.com','13827811311');

# 创建学员成绩表 
CREATE TABLE stu_score( id INT , Excel TINYINT, Tableau TINYINT, MySQL TINYINT ); 
# 向成绩表中插入数据 
INSERT INTO stu_score VALUES 
(1,87,72,88), 
(3,90,66,72), 
(2,90,70,86), 
(4,88,82,76), 
(8,92,67,80), 
(10,88,82,89), 
(5,79,66,60), 
(7,91,78,90), 
(6,82,79,88), 
(9,85,70,85); 

# 1.查询年龄超过所有学员平均年龄的学员信息 
SELECT * FROM stu_info 
WHERE age >= avg(age); 
#需要注意的是Where后面不能使用聚合函数
#应该修改成
SELECT AVG(age) FROM stu_info;
SELECT * FROM stu_info
WHERE age>=23.3
#二合一 
# 1.查询年龄超过所有学员平均年龄的学员信息 
SELECT * FROM stu_info 
WHERE age >= (SELECT AVG(age) FROM stu_info);

# 2.查询年龄不低于所属系平均年龄的学员信息 
SELECT * FROM stu_info AS s1 
WHERE age>= ( SELECT avg(age) FROM stu_info AS s2 
			  WHERE s1.department = s2.department);

比較演算子を含むネストされたクエリを使用する場合、比較演算子の後のサブクエリは 1 つの結果しか返せないことに注意してください。

(2) ANY または ALL キーワードを含むネストされたクエリ
比較演算子を含むネストされたクエリの場合、クエリ ステートメントのネストされた部分は 1 つの値のみを返すことができます。サブクエリが複数の値を返す場合は、ANY または ALL キーワードを使用する必要があります。通常、ANY / ALL キーワードは比較演算子とともに使用されることが多く、6 つの比較演算子と ANY / ALL キーワードを組み合わせた結果は次のとおりです。ここでクエリを実行します。 ロジックは次のとおりです。最初に管理部門の学生の年齢をクエリし (重複を削除)、得られた結果は 22 歳と 24 歳です。次に、非管理部門の 22 歳未満の学生の情報をクエリします。 24名(つまり24歳未満の非管理学生。管理学生情報)。 mysqlにネストされたクエリステートメントはありますか?

# 1.查询非管理系中比管理系任意一个学员年龄小的学员信息 SELECT * FROM stu_info 
WHERE age <p><img src="https://img.php.cn/upload/article/000/000/067/4324f62c03299e4da154e72d7d28ebb8-1.png" alt="mysqlにネストされたクエリステートメントはありますか?"> ここでのクエリ ロジックは次のとおりです。最初に管理部門の学生の年齢をクエリし (重複を削除)、得られた結果は 22 と 24 で、次に年齢をクエリします。非管理部門の学生の割合 22 歳と 24 歳の両方の学生に関する情報 (つまり、24 歳以上の非管理部門の学生に関する情報)。 <br></p>(3) IN キーワードを含むネストされたクエリ<p> クエリ条件に特定の既知の列挙可能な離散値が含まれる場合、IN キーワードを選択してデータ抽出を完了できます。 IN キーワードには 2 つの用途があります。 <img src="https://img.php.cn/upload/article/000/000/067/04e24e95f5a07ea7eb7b74527b597587-2.png" alt="mysqlにネストされたクエリステートメントはありますか?"><br></p>列挙可能な離散値を値リストに直接書き込む<p><br>離散値が他のテーブルのフィルタリング結果に基づいている場合、次のように使用できます。ネストされたクエリ。つまり、IN キーワードの後に​​かっこ内に別のテーブルのクエリ ステートメント ブロックを記述します。 </p><ol>
<pre class="brush:php;toolbar:false"># 2.查询非管理系中比管理系所有学员年龄大的学员信息 SELECT * FROM stu_info 
WHERE age > ALL (SELECT DISTINCT age FROM stu_info WHERE department = '管理系') 
      AND department != '管理系';
  • IN キーワードのネストされたクエリを使用する場合、ネストされた部分は 1 つのフィールド (上記の部門フィールドや ID フィールドなど) に関する情報のみを返すことができることに注意してください。戻り値 フィールド情報が 2 つ以上ある場合、構文エラーが発生します。
  • (4) EXISTS キーワードを含むネストされたクエリ
  • EXISTS キーワードの役割は IN キーワードとよく似ていますが、EXISTS キーワードを使用したネストされたクエリは特定の値を返さない点が異なります。設定されますが、条件を満たす論理値 (つまり、True/False) です。つまり、EXISTSの機能は「ある条件を満たすレコードが存在するかどうかを判定する」ことであり、そのようなレコードが存在する場合はTrue(True)を返し、そのようなレコードが存在しない場合はFalse(False)を返します。 。
    # 1.查询数学系和计算机系的学员信息 
    SELECT * FROM stu_info WHERE department IN('数学系','计算机系'); 
    # 2.查询与张勇、刘伟同一个系的学员信息 
    SELECT * FROM stu_info 
    WHERE department IN (SELECT department FROM stu_info WHERE iname IN('张勇','刘伟')); 
    # 3.查询MySQL成绩大于85分的学员信息 
    SELECT * FROM stu_info 
    WHERE id IN (SELECT id FROM stu_score WHERE MySQL > 85);

    EXISTS キーワードを使用したネストされたステートメント WHERE と EXISTS キーワードの間にパラメーターがないことに注意してください。これは、EXISTS に必要なパラメーターは 1 つだけであり、通常は EXISTS の右側にサブクエリを追加するためです。 。さらに、EXISTS の後のサブクエリでは、条件を満たすレコードがあるかどうかのみを考慮するため、EXISTS の後のサブクエリでは、テーブル内の任意のフィールド、または SELECT の後にアスタリスクまたは定数を記述することができます。以下に返される結果はすべて同じです。

    [補足] IN と EXISTS の 2 つのキーワードについては、NOT IN と NOT EXISTS の 2 つの拡張キーワードがあります。

    # 查询MySQL成绩大于85分的学员信息 SELECT * FROM stu_info 
    WHERE EXISTS(SELECT * FROM stu_score WHERE stu_score.id = stu_info.id AND MySQL > 85);
    2 つのキーワード IN と EXISTS については、ほとんどの場合、キーワードは相互に置き換えることができます。主な違いは使用効率です。通常、EXISTS を使用する方が IN よりも効率的ですが、実際の状況にも依存します。IN は大規模な外部テーブルと小規模な内部テーブルに適しています。 . シチュエーション; EXISTS は、見た目は小さくても中は広いというシチュエーションに適しています。

    上記では、where ステートメントの後のサブクエリについてのみ学習しましたが、さらに、サブクエリは select ステートメント、from ステートメント、having ステートメントの後に配置することもできます。

    推奨学習:

    mysql ビデオ チュートリアル

    以上がmysqlにネストされたクエリステートメントはありますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

    声明:
    この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。