mysql supports subqueries. Subquery refers to nesting a query statement within another query statement. It is a commonly used query method in MySQL. Multi-table queries can be implemented through subqueries. Subqueries can be used in SELECT, UPDATE and DELETE statements, and can be nested at multiple levels; in actual development, subqueries often appear in the WHERE clause, and the syntax is "WHERE
(subquery)", the subquery must be closed in parentheses.
The operating environment of this tutorial: windows7 system, mysql8 version, Dell G3 computer.
mysql supports subqueries.
Subquery in MySQL
Subquery is a commonly used query method in MySQL. Multi-table query can be realized through subquery. Subquery refers to nesting one query statement within another query statement. Subqueries can be used in SELECT, UPDATE, and DELETE statements and can be nested at multiple levels. In actual development, subqueries often appear in the WHERE clause.
The syntax format of the subquery in WHERE is as follows:
WHERE <表达式> <操作符> (子查询)
Among them, the operator can be a comparison operator and keywords such as IN, NOT IN, EXISTS, NOT EXISTS; the subquery must be in Closed in brackets
1) IN | NOT IN
Returns TRUE when the expression is equal to a value in the result set returned by the subquery, otherwise it returns FALSE ; If the keyword NOT is used, the return value is exactly the opposite.
2) EXISTS | NOT EXISTS
is used to determine whether the result set of the subquery is empty. If the result set of the subquery is not empty, TRUE is returned, otherwise it is returned FALSE; if keyword NOT is used, the returned value is exactly the opposite.
Example 1
Use subquery to query the names of students studying Java courses in the tb_students_info table and tb_course table
mysql> SELECT name FROM tb_students_info -> WHERE course_id IN (SELECT id FROM tb_course WHERE course_name = 'Java');
The results show that only Dany and Henry are taking Java courses. The above query process can also be divided into the following two steps to achieve the same effect.
1) First execute the inner query separately to find out the ID of the course Java in the tb_course table. The SQL statement and running results are as follows.
mysql> SELECT id FROM tb_course -> WHERE course_name = 'Java';
#As you can see, the value of the id field that meets the conditions is 1.
2) Then execute the outer query to query the names of students whose course_id is equal to 1 in the tb_students_info table. The SQL statements and running results are as follows.
mysql> SELECT name FROM tb_students_info -> WHERE course_id IN (1);
Conventionally, the outer SELECT query is called the parent query, and the query embedded in parentheses is called a subquery (The subquery must be placed in parentheses Inside). When MySQL processes the SELECT statement in the above example, the execution flow is: first execute the subquery, and then execute the parent query.
Example 2
Similar to Example 1, use the NOT IN keyword in the SELECT statement to query the names of students who have not taken Java courses. The SQL statement and running results are as follows .
mysql> SELECT name FROM tb_students_info -> WHERE course_id NOT IN (SELECT id FROM tb_course WHERE course_name = 'Java');
It can be seen that the running results are exactly the opposite of Example 1. Students other than Dany and Henry are not taking Java courses.
Example 3
Use the =
operator to query the names of all students studying Python courses in the tb_course table and tb_students_info table, SQL statement And the running results are as follows.
mysql> SELECT name FROM tb_students_info -> WHERE course_id = (SELECT id FROM tb_course WHERE course_name = 'Python');
The results show that the only student studying the Python course is Jane.
Example 4
Use the operator to query the names of students who have not studied Python courses in the tb_course table and tb_students_info table , the SQL statements and running results are as follows.
mysql> SELECT name FROM tb_students_info -> WHERE course_id <> (SELECT id FROM tb_course WHERE course_name = 'Python');
It can be seen that the running result is just the opposite of Example 3. The students other than Jane are not learning Python courses.
Example 5
Query whether there is a course with id=1 in the tb_course table. If it exists, query the records in the tb_students_info table. The SQL statement and running results are as follows .
mysql> SELECT * FROM tb_students_info -> WHERE EXISTS(SELECT course_name FROM tb_course WHERE id=1);
As can be seen from the results, there is a record with id=1 in the tb_course table, so the EXISTS expression returns TRUE, and the outer query statement receives TRUE and then performs the query on the table tb_students_info Query to return all records.
EXISTS 关键字可以和其它查询条件一起使用,条件表达式与 EXISTS 关键字之间用 AND 和 OR 连接。
例 6
查询 tb_course 表中是否存在 id=1 的课程,如果存在,就查询出 tb_students_info 表中 age 字段大于 24 的记录,SQL 语句和运行结果如下。
mysql> SELECT * FROM tb_students_info -> WHERE age>24 AND EXISTS(SELECT course_name FROM tb_course WHERE id=1);
结果显示,从 tb_students_info 表中查询出了一条记录,这条记录的 age 字段取值为 25。内层查询语句从 tb_course 表中查询到记录,返回 TRUE。外层查询语句开始进行查询。根据查询条件,从 tb_students_info 表中查询 age 大于 24 的记录。
拓展
子查询的功能也可以通过表连接完成,但是子查询会使 SQL 语句更容易阅读和编写。
一般来说,表连接(内连接和外连接等)都可以用子查询替换,但反过来却不一定,有的子查询不能用表连接来替换。子查询比较灵活、方便、形式多样,适合作为查询的筛选条件,而表连接更适合于查看连接表的数据。
【相关推荐:mysql视频教程】
The above is the detailed content of Does mysql not support subqueries?. For more information, please follow other related articles on the PHP Chinese website!

MySQL's position in databases and programming is very important. It is an open source relational database management system that is widely used in various application scenarios. 1) MySQL provides efficient data storage, organization and retrieval functions, supporting Web, mobile and enterprise-level systems. 2) It uses a client-server architecture, supports multiple storage engines and index optimization. 3) Basic usages include creating tables and inserting data, and advanced usages involve multi-table JOINs and complex queries. 4) Frequently asked questions such as SQL syntax errors and performance issues can be debugged through the EXPLAIN command and slow query log. 5) Performance optimization methods include rational use of indexes, optimized query and use of caches. Best practices include using transactions and PreparedStatemen

MySQL is suitable for small and large enterprises. 1) Small businesses can use MySQL for basic data management, such as storing customer information. 2) Large enterprises can use MySQL to process massive data and complex business logic to optimize query performance and transaction processing.

InnoDB effectively prevents phantom reading through Next-KeyLocking mechanism. 1) Next-KeyLocking combines row lock and gap lock to lock records and their gaps to prevent new records from being inserted. 2) In practical applications, by optimizing query and adjusting isolation levels, lock competition can be reduced and concurrency performance can be improved.

MySQL is not a programming language, but its query language SQL has the characteristics of a programming language: 1. SQL supports conditional judgment, loops and variable operations; 2. Through stored procedures, triggers and functions, users can perform complex logical operations in the database.

MySQL is an open source relational database management system, mainly used to store and retrieve data quickly and reliably. Its working principle includes client requests, query resolution, execution of queries and return results. Examples of usage include creating tables, inserting and querying data, and advanced features such as JOIN operations. Common errors involve SQL syntax, data types, and permissions, and optimization suggestions include the use of indexes, optimized queries, and partitioning of tables.

MySQL is an open source relational database management system suitable for data storage, management, query and security. 1. It supports a variety of operating systems and is widely used in Web applications and other fields. 2. Through the client-server architecture and different storage engines, MySQL processes data efficiently. 3. Basic usage includes creating databases and tables, inserting, querying and updating data. 4. Advanced usage involves complex queries and stored procedures. 5. Common errors can be debugged through the EXPLAIN statement. 6. Performance optimization includes the rational use of indexes and optimized query statements.

MySQL is chosen for its performance, reliability, ease of use, and community support. 1.MySQL provides efficient data storage and retrieval functions, supporting multiple data types and advanced query operations. 2. Adopt client-server architecture and multiple storage engines to support transaction and query optimization. 3. Easy to use, supports a variety of operating systems and programming languages. 4. Have strong community support and provide rich resources and solutions.

InnoDB's lock mechanisms include shared locks, exclusive locks, intention locks, record locks, gap locks and next key locks. 1. Shared lock allows transactions to read data without preventing other transactions from reading. 2. Exclusive lock prevents other transactions from reading and modifying data. 3. Intention lock optimizes lock efficiency. 4. Record lock lock index record. 5. Gap lock locks index recording gap. 6. The next key lock is a combination of record lock and gap lock to ensure data consistency.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

DVWA
Damn Vulnerable Web App (DVWA) is a PHP/MySQL web application that is very vulnerable. Its main goals are to be an aid for security professionals to test their skills and tools in a legal environment, to help web developers better understand the process of securing web applications, and to help teachers/students teach/learn in a classroom environment Web application security. The goal of DVWA is to practice some of the most common web vulnerabilities through a simple and straightforward interface, with varying degrees of difficulty. Please note that this software

VSCode Windows 64-bit Download
A free and powerful IDE editor launched by Microsoft

MinGW - Minimalist GNU for Windows
This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment

WebStorm Mac version
Useful JavaScript development tools