Problems encountered in the execution order of AND and OR in SQL statements

Problems encountered in the execution order of AND and OR in SQL statements

question

I encountered a problem when writing database SQL yesterday. The root of the problem lies in the execution priority of the AND and OR keywords in SQL statements. Let's test this issue.

Scenario

1. There is a student table Student, the table fields include Id (user primary key), Name (user name), Grade (grade), Class (class), Sex (gender). as follows:

Table Structure

2. Import ten test data into the table as follows:

Table Data

3. Now you need to find out the female students in grade 1 who are female, or the female students in class 2 who are female. The SQL statement is as follows:
select * from student where sex='女' and grade=1 or class=2
However, the result of the SQL query does not meet the requirements. The execution results are as follows:

Execution Results

The execution result also found male students in class 2, which is obviously incorrect.

4. Modify the SQL statement and add brackets. as follows:

select * from student where sex='女' and (grade=1 or class=2)

The result of the SQL query meets the requirements

analyze

From the above scenario, the key to the problem lies in the execution order of AND and OR.
According to the data, the priority of relational operators from high to low is: NOT >AND >OR
If there is an OR condition after where, OR will automatically separate the left and right query conditions.
Just like the first statement in the above scenario, its query condition is divided into two parts (or):

1. sex = 'female' and grade = 1
2. class=2

This means finding out the female students in grade 1 and the students in class 2. Does not meet the requirements of the original query.
The solution is to use brackets to distinguish the order of execution <br /> As in the second statement in the above scenario, the query condition is divided into two parts (and):

1. sex = 'female' 
2. (grade=1 or class=2)

You may also be interested in:
  • SQL statement execution order graphic description
  • Detailed explanation of SQL statement execution order
  • In-depth explanation of SQL statement execution (MySQL architecture overview -> query execution process -> SQL parsing order)
  • Learn SQL query execution order from scratch
  • This article tells you what the execution order of Sql is

<<:  Linux (center OS7) installs JDK, tomcat, mysql to build a java web project running environment

>>:  How to use axios to filter multiple repeated requests in a project

Recommend

Summary of MySQL logical backup and recovery testing

Table of contents 1. What kind of backup is a dat...

Reasons and solutions for slow MySQL query stuck in sending data

Because I wrote a Python program and intensively ...

CSS menu button animation

To write a drop-down menu, click the button. The ...

Example of how to implement value transfer between WeChat mini program pages

Passing values ​​between mini program pages Good ...

Docker images export and import operations

What if the basic images have been configured bef...

SQL interview question: Find the sum of time differences (ignore duplicates)

When I was interviewing for a BI position at a ce...

Boundary and range description of between in mysql

mysql between boundary range The range of between...

Optimized record of using IN data volume in Mysql

The MySQL version number is 5.7.28. Table A has 3...

HTML&CSS&JS compatibility tree (IE, Firefox, Chrome)

What is a tree in web design? Simply put, clicking...

MySQL database implements OLTP benchmark test based on sysbench

Sysbench is an excellent benchmark tool that can ...

A brief discussion on CSS blocking merging and other effects

Non-orthogonal margins When margin is used, it wi...

A brief talk on responsive design

1. What is responsive design? Responsive design i...

Commonplace talk about the usage of MYSQL pattern matching REGEXP and like

like LIKE requires the entire data to match, whil...