not exists usage
not exists is a syntax in SQL. It is commonly used between subqueries and main queries. It is used for conditional judgment. It returns a Boolean value based on a condition to determine how to proceed with the next operation. The same is true for not exists. The opposite of exists or in.
Not exists is the opposite of exists, so to understand the usage of not exists, we first understand the differences and characteristics of exists and in:
exists: The emphasis is on whether to return the result set, without knowing what to return. For example:
select name from student where sex = 'm' and mark exists(select 1 from grade where ...)
As long as the exists guide clause returns the result set, then the exists condition is established. Please pay attention to the fields returned. It is always 1. If it is changed to "select 2 from grade where...", then the returned field is 2, and this number is meaningless. So the exists clause does not care about what is returned, but whether there is a result set returned.
The biggest difference between exists and in is that the in clause can only return one field, for example:
select name from student where sex = 'm' and mark in (select 1,2,3 from grade where ...)
The in clause returns three fields, which is incorrect, exists The clause is allowed, but in only allows one field to be returned. Just remove any two fields in 1, 2, and 3.
Not exists and not in are the opposites of exists and in respectively.
exists (sql 返回结果集,为真)
Mainly depends on whether the sql statement result in exists brackets has a result. If there is a result: the where condition will continue to be executed; if there is no result: it is considered that the where condition is not established.
not exists (sql 不返回结果集,为真)
Mainly depends on whether the sql statement in the not exists brackets has a result. If there is no result: the where condition will continue to be executed; if there is a result: the where condition is deemed not to be true.
not exists: After testing, when the subquery and the main query have related conditions, it is equivalent to removing the subquery data from the main query.
For example:
test data: id name
1 1 Zhang San
2 李四
select * from test c where not exists (select 1 from test t where t.id= '1' ) --无结果
select * from test c where not exists (select 1 from test t where t.id= '1' and t.id = c.id) --返回2 李四
The above is the detailed content of not exists usage. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undress AI Tool
Undress images for free

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

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

Clothoff.io
AI clothes remover

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

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

SQL is used to interact with MySQL database to realize data addition, deletion, modification, inspection and database design. 1) SQL performs data operations through SELECT, INSERT, UPDATE, DELETE statements; 2) Use CREATE, ALTER, DROP statements for database design and management; 3) Complex queries and data analysis are implemented through SQL to improve business decision-making efficiency.

MySQL is popular because of its excellent performance and ease of use and maintenance. 1. Create database and tables: Use the CREATEDATABASE and CREATETABLE commands. 2. Insert and query data: operate data through INSERTINTO and SELECT statements. 3. Optimize query: Use indexes and EXPLAIN statements to improve performance.

The relationship between SQL and MySQL is: SQL is a language used to manage and operate databases, while MySQL is a database management system that supports SQL. 1.SQL allows CRUD operations and advanced queries of data. 2.MySQL provides indexing, transactions and locking mechanisms to improve performance and security. 3. Optimizing MySQL performance requires attention to query optimization, database design and monitoring and maintenance.

SQL is a standard language for managing relational databases, while MySQL is a database management system that uses SQL. SQL defines ways to interact with a database, including CRUD operations, while MySQL implements the SQL standard and provides additional features such as stored procedures and triggers.

The relationship between SQL and MySQL is the relationship between standard languages and specific implementations. 1.SQL is a standard language used to manage and operate relational databases, allowing data addition, deletion, modification and query. 2.MySQL is a specific database management system that uses SQL as its operating language and provides efficient data storage and management.

The difference and connection between SQL and MySQL are as follows: 1.SQL is a standard language used to manage relational databases, and MySQL is a database management system based on SQL. 2.SQL provides basic CRUD operations, and MySQL adds stored procedures, triggers and other functions on this basis. 3. SQL syntax standardization, MySQL has been improved in some places, such as LIMIT used to limit the number of returned rows. 4. In the usage example, the query syntax of SQL and MySQL is slightly different, and the JOIN and GROUPBY of MySQL are more intuitive. 5. Common errors include syntax errors and performance issues. MySQL's EXPLAIN command can be used for debugging and optimizing queries.

In practical applications, SQL is mainly used for data query and analysis, data integration and reporting, data cleaning and preprocessing, advanced usage and optimization, as well as handling complex queries and avoiding common errors. 1) Data query and analysis can be used to find the most sales product; 2) Data integration and reporting generate customer purchase reports through JOIN operations; 3) Data cleaning and preprocessing can delete abnormal age records; 4) Advanced usage and optimization include using window functions and creating indexes; 5) CTE and JOIN can be used to handle complex queries to avoid common errors such as SQL injection.

The SQL learning curve is steep, but it can be mastered through practice and understanding the core concepts. 1. Basic operations include SELECT, INSERT, UPDATE, DELETE. 2. Query execution is divided into three steps: analysis, optimization and execution. 3. Basic usage is such as querying employee information, and advanced usage is such as using JOIN connection table. 4. Common errors include not using alias and SQL injection, and parameterized query is required to prevent it. 5. Performance optimization is achieved by selecting necessary columns and maintaining code readability.
