MySQL - IS NULL 运算符
- MySQL IS NULL 运算符
- SELECT 语句中的 IS NULL
- COUNT() 函数中的 IS NULL
- UPDATE 语句中的 IS NULL
- DELETE 语句中的 IS NULL
- 使用客户端程序的 IS NULL 运算符
MySQL 表字段中的 NULL 值表示其中不存在(或存在未知)值。这些值不同于零或无效值。
在 MySQL 中,无法使用 =、< 或 <> 等比较运算符检查 NULL 值。相反,我们使用 IS NULL 和 IS NOT NULL(过滤非空值)运算符。
MySQL IS NULL 运算符
MySQL 中的 IS NULL 运算符用于检查列中的值是否为 NULL。将 IS NULL 运算符与条件子句结合使用,可以筛选出特定列中包含 NULL 值的记录。
我们也可以将此运算符与 SELECT、UPDATE 和 DELETE SQL 语句结合使用。
语法
以下是 MySQL 中 IS NULL 的语法 -
SELECT column_name1, column_name2, ... FROM table_name WHERE column_name IS NULL;
示例
首先,我们使用以下查询创建一个名为 CUSTOMERS 的表 -
CREATE TABLE CUSTOMERS ( ID INT NOT NULL, NAME VARCHAR (20) NOT NULL, AGE INT, ADDRESS CHAR (25), SALARY DECIMAL (18, 2), PRIMARY KEY (ID) );
在以下查询中,我们使用INSERT语句将值插入表中 -
INSERT INTO CUSTOMERS VALUES (1, 'Ramesh', 32, 'Ahmedabad', NULL), (2, 'Khilan', 25, 'Delhi', 1500.00), (3, 'Kaushik', NULL, 'Kota', 2000.00), (4, 'Chaitali', 25, 'Mumbai', NULL), (5, 'Hardik', 27, 'Bhopal', 8500.00), (6, 'Komal', NULL, 'Hyderabad', 4500.00), (7, 'Muffy', 24, 'Indore', 10000.00);
表的创建如下 -
ID | NAME | AGE | ADDRESS | SALARY |
---|---|---|---|---|
1 | Ramesh | 32 | Ahmedabad | NULL |
2 | Khilan | 25 | Delhi | 1500.00 |
3 | Kaushik | NULL | Kota | 2000.00 |
4 | Chaitali | 25 | Mumbai | NULL |
5 | Hardik | 27 | Bhopal | 8500.00 |
6 | Komal | NULL | Hyderabad | 4500.00 |
7 | Muffy | 24 | Indore | 10000.00 |
使用 SELECT 语句判断 IS NULL
MySQL 的 IS NULL 运算符可与 SELECT 语句一起使用,以筛选包含 NULL 值的记录。
示例
在以下查询中,我们将返回 CUSTOMERS 表中所有 AGE 为 null 的记录。
SELECT * FROM CUSTOMERS WHERE AGE IS NULL;
输出
执行上述查询后,将生成如下所示的输出 -
ID | NAME | AGE | ADDRESS | SALARY |
---|---|---|---|---|
3 | Kaushik | NULL | Kota | 20000.00 |
6 | Komal | NULL | Hyderabad | 20000.00 |
使用 COUNT() 函数判断 IS NULL
我们可以使用 MySQL 的 IS NULL 运算符和 COUNT() 函数来统计特定列中 NULL 值的记录数。
语法
以下是 MySQL 中 IS NULL 函数的语法 -
SELECT COUNT(column_name1, column_name2, ...) FROM table_name WHERE condition IS NULL;
示例
以下查询返回 CUSTOMERS 表中 ADDRESS 列中包含空字段 (NULL) 的记录数。
SELECT COUNT(*) FROM CUSTOMERS WHERE ADDRESS IS NULL;
输出
执行上述查询后,将生成如下所示的输出 -
COUNT(*) |
---|
2 |
UPDATE 语句中的 IS NULL
在 MySQL 中,我们可以将 IS NULL 运算符与 UPDATE 语句结合使用,以更新特定列中具有 NULL 值的记录。
语法
以下是 MySQL 中 IS NULL 运算符与 UPDATE 语句的语法 -
UPDATE table_name SET column1 = value1, column2 = value2, ... WHERE columnname1, columnname2, ... IS NULL;
示例
在以下查询中,我们将 SALARY 列的空白 (NULL) 记录更新为值 9000。
UPDATE CUSTOMERS SET SALARY = 9000 WHERE SALARY IS NULL;
验证
要检查表是否已更新,请执行 SELECT 查询以显示表。
ID | NAME | AGE | ADDRESS | SALARY |
---|---|---|---|---|
1 | Ramesh | 32 | Ahmedabad | 9000.00 |
2 | Khilan | 25 | Delhi | 1500.00 |
3 | Kaushik | NULL | Kota | 2000.00 |
4 | Chaitali | 25 | Mumbai | 9000.00 |
5 | Hardik | 27 | Bhopal | 8500.00 |
6 | Komal | NULL | Hyderabad | 4500.00 |
7 | Muffy | 24 | Indore | 10000.00 |
DELETE 语句中的 IS NULL 值
在 MySQL 中,我们可以将 IS NULL 运算符与 DELETE 语句结合使用,删除特定列中值为 NULL 的记录。
语法
以下是 MySQL 中 DELETE 语句中 IS NULL 运算符的语法 -
DELETE FROM table_name WHERE column_name(s) IS NULL;
示例
在以下查询中,我们尝试删除 CUSTOMERS 表 ADDRESS 列中的空白 (NULL) 记录。
DELETE FROM CUSTOMERS WHERE AGE IS NULL;
验证
要检查表是否已更改,请执行 SELECT 查询以显示表。
ID | NAME | AGE | ADDRESS | SALARY |
---|---|---|---|---|
1 | Ramesh | 32 | Ahmedabad | NULL |
2 | Khilan | 25 | Delhi | 1500.00 |
4 | Chaitali | 25 | Mumbai | NULL |
5 | Hardik | 27 | Bhopal | 8500.00 |
7 | Muffy | 24 | Indore | 10000.00 |
使用客户端程序执行 IS NULL 运算符
除了使用 SQL 查询在 MySQL 服务器上执行 IS NULL 运算符外,我们还可以使用客户端程序执行它。
语法
以下是不同编程语言中 MySQL 表中 IS NULL 运算符的语法 -
要通过 PHP 程序在 MySQL 中执行 IS NULL 运算符,我们需要使用名为 mysqli 的函数 query() 执行带有 IS NULL 运算符的 SQL 查询,如下所示:-
$sql = "SELECT column_name1, column_name2, ... FROM table_name WHERE column_name IS NULL"; $mysqli->query($sql);
要通过 JavaScript 程序在 MySQL 中执行 IS NULL 运算符,我们需要使用名为 query() 的 mysql2 函数执行带有 IS NULL 运算符的 SQL 查询,如下所示:-
sql= " SELECT column_name1, column_name2, ... FROM table_name WHERE column_name IS NULL"; con.query(sql);
要通过 Java 程序在 MySQL 中执行 IS NULL 运算符,我们需要使用 JDBC type 4 驱动程序提供的名为 executeQuery() 的函数执行带有 IS NULL 运算符的 SQL 查询 -
String sql = "SELECT column_name1, column_name2, ... FROM table_name WHERE column_name IS NULL"; statement.executeQuery(sql);
要通过 Python 程序在 MySQL 中执行 IS NULL 运算符,我们需要使用 MySQL Connector/Python 提供的名为 execute() 的函数执行带有 IS NULL 运算符的 SQL 查询 -
is_null_query = "SELECT column_name1, column_name2, ... FROM table_name WHERE column_name IS NULL" cursorObj.execute(is_null_query);
示例
以下是此操作在各种编程语言中的实现 -
$dbhost = 'localhost'; $dbuser = 'root'; $dbpass = 'password'; $dbname = 'TUTORIALS'; $mysqli = new mysqli($dbhost, $dbuser, $dbpass, $dbname); if($mysqli->connect_errno ) { printf("Connect failed: %s
", $mysqli->connect_error); exit(); } //printf('Connected successfully.
'); $sql = "SELECT * FROM CUSTOMERS WHERE AGE IS NULL"; $result = $mysqli->query($sql); if ($result->num_rows > 0) { printf("Table records: "); while($row = $result->fetch_assoc()) { printf("Id %d, Name: %s, Age: %d, Address %s, Salary %f", $row["ID"], $row["NAME"], $row["AGE"], $row["ADDRESS"], $row["SALARY"]); printf(" "); } } else { printf('No record found.
'); } mysqli_free_result($result); $mysqli->close();
输出
获得的输出如下 -
Table records: Id 3, Name: kaushik, Age: 0, Address Hyderabad, Salary 2000.000000 Id 6, Name: Komal, Age: 0, Address Vishakapatnam, Salary 4500.000000
var mysql = require('mysql2'); var con = mysql.createConnection({ host: "localhost", user: "root", password: "Nr5a0204@123" }); //连接到 MySQL con.connect(function (err) { if (err) throw err; console.log("Connected!"); console.log("--------------------------"); //创建数据库 sql = "create database TUTORIALS" con.query(sql); //选择数据库 sql = "USE TUTORIALS" con.query(sql); //创建 CUSTOMERS 表 sql = "CREATE TABLE CUSTOMERS(ID INT NOT NULL,NAME VARCHAR(20),AGE INT,ADDRESS CHAR(25),SALARY DECIMAL(18, 2),PRIMARY KEY(ID));" con.query(sql); //插入记录 sql = "INSERT INTO CUSTOMERS(ID, NAME, AGE, ADDRESS, SALARY) VALUES(1,'Ramesh', 32, 'Hyderabad',NULL),(2,'Khilan', 25, NULL, 1500.00),(3,'kaushik', NULL, 'Hyderabad', 2000.00),(4,'Chaital', 25, 'Mumbai', NULL),(5,'Hardik', 27, 'Vishakapatnam', 8500.00),(6, 'Komal',NULL, 'Vishakapatnam', 4500.00),(7, 'Muffy',24, NULL, 10000.00);" con.query(sql); //Using IS NULL Operator sql = "SELECT * FROM CUSTOMERS WHERE AGE IS NULL;" con.query(sql, function(err, result){ if (err) throw err console.log(result) }); });
输出
生成的输出如下 -
Connected! -------------------------- [ { ID: 3, NAME: 'kaushik', AGE: null, ADDRESS: 'Hyderabad', SALARY: '2000.00' }, { ID: 6, NAME: 'Komal', AGE: null, ADDRESS: 'Vishakapatnam', SALARY: '4500.00' } ]
import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.Statement; public class IsNullOperator { public static void main(String[] args) { String url = "jdbc:mysql://localhost:3306/TUTORIALS"; String user = "root"; String password = "password"; ResultSet rs; try { Class.forName("com.mysql.cj.jdbc.Driver"); Connection con = DriverManager.getConnection(url, user, password); Statement st = con.createStatement(); //System.out.println("Database connected successfully...!"); String sql = " SELECT * FROM CUSTOMERS WHERE AGE IS NULL"; rs = st.executeQuery(sql); System.out.println("Table records: "); while(rs.next()) { String id = rs.getString("Id"); String name = rs.getString("Name"); String age = rs.getString("Age"); String address = rs.getString("Address"); String salary = rs.getString("Salary"); System.out.println("Id: " + id + ", Name: " + name + ", Age: " + age + ", Addresss: " + address + ", Salary: " + salary); } }catch(Exception e) { e.printStackTrace(); } } }
输出
获得的输出如下所示 -
Table records: Id: 3, Name: kaushik, Age: null, Addresss: Hyderabad, Salary: 2000.00 Id: 6, Name: Komal, Age: null, Addresss: Vishakapatnam, Salary: 4500.00
import mysql.connector #建立连接 connection = mysql.connector.connect( host='localhost', user='root', password='password', database='tut' ) cursorObj = connection.cursor() is_null_query = f""" SELECT * FROM CUSTOMERS WHERE AGE IS NULL; """ cursorObj.execute(is_null_query) # 获取所有符合条件的行 filtered_rows = cursorObj.fetchall() for row in filtered_rows: print(row) cursorObj.close() connection.close()
输出
以下是上述代码的输出 -
(3, 'kaushik', None, 'Hyderabad', Decimal('2000.00')) (6, 'Komal', None, 'Vishakapatnam', Decimal('4500.00'))