pgsql 查询9-12已登且1-5月未登客户
时间: 2024-01-13 19:02:27 浏览: 19
您好!针对您的问题,可以使用以下SQL查询语句:
```
SELECT *
FROM customers
WHERE status = '已登'
AND EXTRACT(MONTH FROM last_login) < 6
AND EXTRACT(MONTH FROM registration_date) BETWEEN 9 AND 12;
```
其中,`customers`为客户表的表名,`status`为客户状态列的列名,`last_login`为最后登录时间列的列名,`registration_date`为注册日期列的列名。
此查询语句会返回所有状态为“已登”、最后登录时间在1-5月之前、注册日期在9-12月之间的客户信息。请根据实际情况修改表名和列名。
相关问题
pgsql 查询2022年9-12已登且2023年1-5月未登客户
您好!针对您的问题,可以使用以下SQL查询语句:
```
SELECT *
FROM customers
WHERE status = '已登'
AND (
(EXTRACT(YEAR FROM last_login) = 2022 AND EXTRACT(MONTH FROM last_login) > 8)
OR
(EXTRACT(YEAR FROM last_login) = 2023 AND EXTRACT(MONTH FROM last_login) < 6)
)
AND EXTRACT(MONTH FROM registration_date) BETWEEN 9 AND 12
AND EXTRACT(YEAR FROM registration_date) = 2022;
```
其中,`customers`为客户表的表名,`status`为客户状态列的列名,`last_login`为最后登录时间列的列名,`registration_date`为注册日期列的列名。
此查询语句会返回所有状态为“已登”、最后登录时间在2022年9月~2023年5月之外、注册日期在2022年9月~12月之间的客户信息。请根据实际情况修改表名和列名。
pgsql查询9-12月已登录且1-5月未登录
可以使用如下的 SQL 查询语句来实现:
```
SELECT *
FROM your_table
WHERE
(EXTRACT(MONTH FROM login_time) >= 9 AND EXTRACT(MONTH FROM login_time) <= 12)
AND user_id NOT IN (
SELECT user_id
FROM your_table
WHERE EXTRACT(MONTH FROM login_time) >= 1 AND EXTRACT(MONTH FROM login_time) <= 5
)
```
其中 `your_table` 是你存储用户登录信息的表,假设该表中包含字段 `user_id` 和 `login_time`,分别表示用户ID和登录时间。具体而言,该查询语句的意思是:查询9-12月份已经登录的用户,且在1-5月份没有登录过的用户。查询结果会返回符合条件的所有行。