在MariaDB中,WHERE子句與SELECT,INSERT,UPDATE和DELETE語句一起使用來選擇或更改想要更改的滿足指定特定行記錄。
它是一個在表名后面出現(xiàn)的語句。
語法
[COMMAND] field,field2,... FROM table_name,table_name2,... WHERE [CONDITION]
注意:
WHERE子句是一個可選的子句。它可以和AND,OR,AND & OR,LIKE運算符一起使用。
示例:
我們有一個表students,里邊有一些數據。假設要查詢students表中的student_id小于6的所有記錄。
SELECT *
FROM Students
WHERE student_id < 6;
執(zhí)行上面查詢語句,得到以下結果 -
MariaDB [testdb]> SELECT *
-> FROM Students
-> WHERE student_id < 6;
+------------+--------------+-----------------+----------------+
| student_id | student_name | student_address | admission_date |
+------------+--------------+-----------------+----------------+
| 1 | Maxsu | Haikou | 2017-01-07 |
| 3 | JMaster | Beijing | 2016-05-07 |
| 4 | Mahesh | Guangzhou | 2016-06-07 |
| 5 | Kobe | Shanghai | 2016-02-07 |
+------------+--------------+-----------------+----------------+
4 rows in set (0.00 sec)
為了方便演示,這里再插入一條數據 -
INSERT INTO students
(student_name, student_address, admission_date)
VALUES('Maxsu','Sanya','2017-08-08 00:00:00');
當前students表中的全部數據是 -
MariaDB [testdb]> select * from students;
+------------+--------------+-----------------+----------------+
| student_id | student_name | student_address | admission_date |
+------------+--------------+-----------------+----------------+
| 1 | Maxsu | Haikou | 2017-01-07 |
| 3 | JMaster | Beijing | 2016-05-07 |
| 4 | Mahesh | Guangzhou | 2016-06-07 |
| 5 | Kobe | Shanghai | 2016-02-07 |
| 6 | Blaba | Shengzhen | 2016-08-07 |
| 7 | Maxsu | Sanya | 2017-08-08 |
+------------+--------------+-----------------+----------------+
6 rows in set (0.00 sec)
現(xiàn)在要查詢students表中的所有列,其中student_name是Maxsu,并且student_id大于1的行記錄。這兩個條件都必須滿足。參考以下查詢語句 -
SELECT *
FROM Students
WHERE student_name = 'Maxsu'
AND student_id >1 ;
執(zhí)行上面查詢語句,得到以下結果 -
MariaDB [testdb]> SELECT *
-> FROM Students
-> WHERE student_name = 'Maxsu'
-> AND student_id >1 ;
+------------+--------------+-----------------+----------------+
| student_id | student_name | student_address | admission_date |
+------------+--------------+-----------------+----------------+
| 7 | Maxsu | Sanya | 2017-08-08 |
+------------+--------------+-----------------+----------------+
1 row in set (0.03 sec)
現(xiàn)在要查詢students表中的所有列,其中student_name是Maxsu,或者student_id大于5的行記錄。這兩個條件滿足其中一個即可。參考以下查詢語句 -
SELECT *
FROM Students
WHERE student_name = 'Maxsu'
OR student_id >5 ;
執(zhí)行上面查詢語句,得到以下結果 -
MariaDB [testdb]> SELECT *
-> FROM Students
-> WHERE student_name = 'Maxsu'
-> OR student_id >5 ;
+------------+--------------+-----------------+----------------+
| student_id | student_name | student_address | admission_date |
+------------+--------------+-----------------+----------------+
| 1 | Maxsu | Haikou | 2017-01-07 |
| 6 | Blaba | Shengzhen | 2016-08-07 |
| 7 | Maxsu | Sanya | 2017-08-08 |
+------------+--------------+-----------------+----------------+
3 rows in set (0.00 sec)
假設要查詢students表中的所有列,那些符合student_name是Ajeet,student_id大于或等于1,或者student_address是Shanghai的行記錄。
SELECT *
FROM Students
WHERE student_name = 'Maxsu'
AND student_id >=1
OR (student_address = 'Shanghai');
執(zhí)行上面查詢語句,得到以下結果 -
MariaDB [testdb]> SELECT *
-> FROM Students
-> WHERE student_name = 'Maxsu'
-> AND student_id >=1
-> OR (student_address = 'Shanghai');
+------------+--------------+-----------------+----------------+
| student_id | student_name | student_address | admission_date |
+------------+--------------+-----------------+----------------+
| 1 | Maxsu | Haikou | 2017-01-07 |
| 5 | Kobe | Shanghai | 2016-02-07 |
| 7 | Maxsu | Sanya | 2017-08-08 |
+------------+--------------+-----------------+----------------+
3 rows in set (0.00 sec)