SQL 基础 | BETWEEN 的常见用法

在SQL中,BETWEEN是一个操作符,用于选取介于两个值之间的数据。

它包含这两个边界值。BETWEEN操作符常用于WHERE子句中,以便选取某个范围内的值。

以下是BETWEEN的一些常见用法:

  1. 选取介于两个值之间的值: 使用 BETWEEN来选取列中的值,这些值大于或等于一个边界值,同时小于或等于另一个边界值。
SELECT column_name(s)
FROM table_name
WHERE column_name BETWEEN value1 AND value2;

例如,选取products表中价格介于10.00和20.00之间的所有产品:

SELECT *
FROM products
WHERE price BETWEEN 10.00 AND 20.00;
  1. 选取日期范围内的记录BETWEEN也常用于选取特定日期范围内的记录。
SELECT *
FROM orders
WHERE order_date BETWEEN '2024-01-01' AND '2024-01-31';

这将返回1月份的所有订单。

  1. **使用 NOT BETWEEN**: NOT BETWEEN操作符与 BETWEEN相反,它选取不在这个范围内的值。
SELECT *
FROM table_name
WHERE column_name NOT BETWEEN value1 AND value2;

例如,选取employees表中工资不在5000到10000之间的员工:

SELECT *
FROM employees
WHERE salary NOT BETWEEN 5000 AND 10000;
  1. 结合LIKE操作符使用BETWEEN可以与 LIKE操作符结合使用,以选取字符串中的一个范围。
SELECT *
FROM customers
WHERE last_name BETWEEN 'A%' AND 'C%';

这个查询将选取姓以A、B或C开头的所有客户。

  1. 使用空值: 如果 BETWEEN的任一端点是 NULL,则结果为假,因为 NULL不等同于任何值。
SELECT *
FROM table_name
WHERE column_name BETWEEN value1 AND NULL;

这个查询不会返回任何行,因为没有任何列的值可以位于一个以NULL为上限的范围内。

  1. 在复杂表达式中使用BETWEEN也可以用于更复杂的表达式,包括函数和计算。
SELECT *
FROM sales
WHERE (quantity * unit_price) BETWEEN 50 AND 200;

这将选取乘积在50到200之间的销售记录。

BETWEEN操作符是SQL中非常有用的工具,它允许你快速选取某个范围内的值。使用BETWEEN可以避免编写多个AND条件,使查询更加简洁。记住,BETWEEN操作符是包含性的,这意味着它包括指定的边界值。

-- END --

alt

如果这篇文章为你带来了灵感或启发,就请帮忙点『赞』or『在看』or『转发』吧,感谢!(๑˃̵ᴗ˂̵)

本文由 mdnice 多平台发布

  • 11
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SQL 中,WHERE 子句用于从表中选择满足指定条件的行。它通常与 SELECT 语句一起使用,以过滤数据并返回符合条件的结果集。 以下是 WHERE 子句的一些常见用法: 1. 简单条件:使用比较操作符(例如 =、<、>、<=、>=)来对特定列的值进行比较。例如: ```sql SELECT * FROM my_table WHERE age > 25; ``` 这将返回 my_table 表中年龄大于 25 的所有行。 2. 多个条件:可以使用 AND、OR 和 NOT 运算符来组合多个条件。例如: ```sql SELECT * FROM my_table WHERE age > 25 AND salary > 50000; ``` 这将返回 my_table 表中年龄大于 25 并且薪资大于 50000 的所有行。 3. 字符串匹配:使用 LIKE 运算符进行模式匹配。例如: ```sql SELECT * FROM my_table WHERE name LIKE 'John%'; ``` 这将返回 my_table 表中名字以 "John" 开头的所有行。 4. IN 子句:使用 IN 关键字来匹配列中的任意一个值。例如: ```sql SELECT * FROM my_table WHERE department IN ('IT', 'Finance', 'HR'); ``` 这将返回 my_table 表中部门为 "IT"、"Finance" 或 "HR" 的所有行。 5. BETWEEN 子句:使用 BETWEEN 关键字来匹配某个范围内的值。例如: ```sql SELECT * FROM my_table WHERE age BETWEEN 20 AND 30; ``` 这将返回 my_table 表中年龄在 20 到 30 之间的所有行。 6. NULL 值:可以使用 IS NULL 或 IS NOT NULL 条件来匹配 NULL 值。例如: ```sql SELECT * FROM my_table WHERE email IS NULL; ``` 这将返回 my_table 表中 email 列为 NULL 的所有行。 请注意,WHERE 子句可以与其他 SQL 语句(如 UPDATE、DELETE)一起使用,以过滤要修改或删除的数据行。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值