?MySQL中?between and的基本用法?操作方法
BETWEEN AND操作符可以用于數(shù)值、日期
等類型的字段,包括邊界值
。
一、between and語法
MySQL中的BETWEEN AND
操作符用于在兩個值之間選擇數(shù)據(jù),包括邊界值
。其基本語法如下:
[NOT] BETWEEN 取值1 AND 取值2
其中:
- NOT:可選參數(shù),表示指定范圍之外的值。如果字段值不滿足指定范圍內(nèi)的值,則這些記錄被返回。
- 取值1:表示范圍的起始值。
- 取值2:表示范圍的終止值。
使用場景:
between…and的使用一般有兩種情況,一個是數(shù)值范圍
,一個是時間范圍
。
當查詢時間范圍時要注意可能會遇到時間精度問題,具體參考下面示例。
二、使用示例
數(shù)據(jù)準備
create table user( id int NOT NULL auto_increment primary key comment '主鍵id', `name` varchar(10) NULL comment '姓名', age int NULL comment '年齡', salary int NULL comment '工資', create_time datetime comment '創(chuàng)建時間戳' ); insert into user(name,age,salary,create_time) values ('張三',23,100,'2024-10-29 10:01:22'), ('李四',24,200,'2024-10-30 09:44:22'), ('王五',25,300,'2024-10-30 10:01:22'), ('趙六',26,400,'2024-10-31 07:01:23');
表數(shù)據(jù)如下
2.1、between and數(shù)值查詢
between…and…是支持數(shù)值查詢的,當字段類型是數(shù)值時 between A and B等同于>=A and <=B
當between and用于數(shù)值查詢時,常用于字段類型為int、decimal等。
-- 查詢用戶表中年齡在24到25之間的用戶 select * from user where age between 24 and 25; 等同于 select * from user where age >= 24 and age <= 25;
查詢結果如下:
2.2、between and時間范圍查詢
注意:
- 當日期字段為date類型時,即時間格式為yyyy-MM-dd, between ‘2024-10-29’ and ‘2024-10-30’ 相當于>=‘2024-10-29’ and <=‘2024-10-30’
- 當日期字段為datetime、timestamp類型時,即時間格式為yyyy-MM-dd HH:mm:ss,between ‘2024-10-29’ and ‘2024-10-30’ 相當于>=‘2024-10-29 00:00:00’ and <=‘2024-10-30 00:00:00’。所以
當between and對datetime、timestamp類型查詢時,一定要注意手動拼接時分秒
,否則查詢數(shù)據(jù)可能不符合預期。
先上一個錯誤示例:對datetime類型查詢不帶時分秒
-- 查詢用戶表中創(chuàng)建時間在2024-10-29到2024-10-30之間的數(shù)據(jù) select * from user where create_time between '2024-10-29' and '2024-10-30'; 等同于 select * from user where create_time >= '2024-10-29 00:00:00' and create_time <= '2024-10-30 00:00:00';
查詢結果:
從上面示例可以看出,還有兩條數(shù)據(jù)時間是在2024-10-30日范圍內(nèi),但是并沒有被查詢出來。
所以需要注意:當between and對datetime、timestamp類型查詢時,一定要注意手動拼接時分秒
,否則查詢數(shù)據(jù)可能不符合預期。
正確示例
-- 查詢用戶表中創(chuàng)建時間在2024-10-29到2024-10-30之間的數(shù)據(jù) select * from user where create_time between '2024-10-29 00:00:00' and '2024-10-30 23:59:59'; 等同于 select * from user where create_time >= '2024-10-29 00:00:00' and create_time <= '2024-10-30 23:59:59';
查詢結果:
2.3、not between and示例
not between and表示指定范圍之外的值。not between A and B相當于 < A or >B。
示例:查詢年齡不在24到25之間的用戶
-- 查詢用戶表中年齡不在24到25之間的用戶 select * from user where age not between 24 and 25; 等同于 select * from user where age < 24 or age > 25;
查詢結果如下:
到此這篇關于MySQL中between and的基本用法的文章就介紹到這了,更多相關mysql between and用法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
xtrabackup備份還原MySQL數(shù)據(jù)庫
這篇文章主要為大家詳細介紹了xtrabackup備份還原MySQL數(shù)據(jù)庫的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-06-06mysql中使用sql命令將時間戳解析成datetime類型存入
這篇文章主要介紹了mysql中使用sql命令將時間戳解析成datetime類型存入,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-11-11