(sub query)", the subquery must be closed in parentheses."/> (sub query)", the subquery must be closed in parentheses.">
HomeDatabaseMysql TutorialDoes mysql not support subqueries?

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.

Does mysql not support subqueries?

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 = &#39;Java&#39;);

Does mysql not support subqueries?

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 = &#39;Java&#39;;

Does mysql not support subqueries?

#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);

Does mysql not support subqueries?

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 = &#39;Java&#39;);

Does mysql not support subqueries?

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 = &#39;Python&#39;);

Does mysql not support subqueries?

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 = &#39;Python&#39;);

Does mysql not support subqueries?

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);

Does mysql not support subqueries?

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);

Does mysql not support subqueries?

结果显示,从 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!

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
MySQL: BLOB and other no-sql storage, what are the differences?MySQL: BLOB and other no-sql storage, what are the differences?May 13, 2025 am 12:14 AM

MySQL'sBLOBissuitableforstoringbinarydatawithinarelationaldatabase,whileNoSQLoptionslikeMongoDB,Redis,andCassandraofferflexible,scalablesolutionsforunstructureddata.BLOBissimplerbutcanslowdownperformancewithlargedata;NoSQLprovidesbetterscalabilityand

MySQL Add User: Syntax, Options, and Security Best PracticesMySQL Add User: Syntax, Options, and Security Best PracticesMay 13, 2025 am 12:12 AM

ToaddauserinMySQL,use:CREATEUSER'username'@'host'IDENTIFIEDBY'password';Here'showtodoitsecurely:1)Choosethehostcarefullytocontrolaccess.2)SetresourcelimitswithoptionslikeMAX_QUERIES_PER_HOUR.3)Usestrong,uniquepasswords.4)EnforceSSL/TLSconnectionswith

MySQL: How to avoid String Data Types common mistakes?MySQL: How to avoid String Data Types common mistakes?May 13, 2025 am 12:09 AM

ToavoidcommonmistakeswithstringdatatypesinMySQL,understandstringtypenuances,choosetherighttype,andmanageencodingandcollationsettingseffectively.1)UseCHARforfixed-lengthstrings,VARCHARforvariable-length,andTEXT/BLOBforlargerdata.2)Setcorrectcharacters

MySQL: String Data Types and ENUMs?MySQL: String Data Types and ENUMs?May 13, 2025 am 12:05 AM

MySQloffersechar, Varchar, text, Anddenumforstringdata.usecharforfixed-Lengthstrings, VarcharerForvariable-Length, text forlarger text, AndenumforenforcingdataAntegritywithaetofvalues.

MySQL BLOB: how to optimize BLOBs requestsMySQL BLOB: how to optimize BLOBs requestsMay 13, 2025 am 12:03 AM

Optimizing MySQLBLOB requests can be done through the following strategies: 1. Reduce the frequency of BLOB query, use independent requests or delay loading; 2. Select the appropriate BLOB type (such as TINYBLOB); 3. Separate the BLOB data into separate tables; 4. Compress the BLOB data at the application layer; 5. Index the BLOB metadata. These methods can effectively improve performance by combining monitoring, caching and data sharding in actual applications.

Adding Users to MySQL: The Complete TutorialAdding Users to MySQL: The Complete TutorialMay 12, 2025 am 12:14 AM

Mastering the method of adding MySQL users is crucial for database administrators and developers because it ensures the security and access control of the database. 1) Create a new user using the CREATEUSER command, 2) Assign permissions through the GRANT command, 3) Use FLUSHPRIVILEGES to ensure permissions take effect, 4) Regularly audit and clean user accounts to maintain performance and security.

Mastering MySQL String Data Types: VARCHAR vs. TEXT vs. CHARMastering MySQL String Data Types: VARCHAR vs. TEXT vs. CHARMay 12, 2025 am 12:12 AM

ChooseCHARforfixed-lengthdata,VARCHARforvariable-lengthdata,andTEXTforlargetextfields.1)CHARisefficientforconsistent-lengthdatalikecodes.2)VARCHARsuitsvariable-lengthdatalikenames,balancingflexibilityandperformance.3)TEXTisidealforlargetextslikeartic

MySQL: String Data Types and Indexing: Best PracticesMySQL: String Data Types and Indexing: Best PracticesMay 12, 2025 am 12:11 AM

Best practices for handling string data types and indexes in MySQL include: 1) Selecting the appropriate string type, such as CHAR for fixed length, VARCHAR for variable length, and TEXT for large text; 2) Be cautious in indexing, avoid over-indexing, and create indexes for common queries; 3) Use prefix indexes and full-text indexes to optimize long string searches; 4) Regularly monitor and optimize indexes to keep indexes small and efficient. Through these methods, we can balance read and write performance and improve database efficiency.

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Dreamweaver Mac version

Dreamweaver Mac version

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

EditPlus Chinese cracked version

EditPlus Chinese cracked version

Small size, syntax highlighting, does not support code prompt function

MinGW - Minimalist GNU for Windows

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.

SecLists

SecLists

SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.