SQL:你如何获取本月的第一天?

时间:2018-03-03 23:09:24

标签: sql sql-server date toad

SQL:你如何获取本月的第一天?

您好,

我需要从每个月的第一天开始从列start_date获取tbl.date。

11/1/2017
12/1/2017
1/1/2018
2/1/2018
ETC.

由于

3 个答案:

答案 0 :(得分:0)

ANSI SQL中的一个解决方案如下所示:

select dte - (1 - extract(day from dte)) * interval '1 day'

在SQL Server中,这将是:

select dateadd(day, 1 - day(dte), dte)

几乎所有数据库都提供类似的功能。

如果您只想要一个月中第一天的行,那么:

where extract(day from dte) = 1

在SQL Server中,这将是:

where day(dte) = 1

当然,语法可能因数据库而异。

答案 1 :(得分:0)

使用Postgres的另一个解决方案,如果您需要选择每个月的第一行,如果无法保证这将是该月的第一天:

CREATE TABLE dates (
     id    BIGSERIAL PRIMARY KEY,
     date  TIMESTAMP NOT NULL
);

INSERT INTO dates(date)
VALUES ('2017-05-05'::timestamp), ('2017-05-02'::timestamp), ('2017-05-30'::timestamp), ('2017-05-25'::timestamp), ('2017-05-15'::timestamp), ('2017-05-01'::timestamp), ('2017-06-10'::timestamp), ('2017-06-02');

SELECT DISTINCT ON(EXTRACT(MONTH FROM date), EXTRACT(YEAR FROM date)) date
FROM dates
ORDER BY EXTRACT(MONTH FROM date), EXTRACT(YEAR FROM date), date ASC;

结果:

date
--------------------
2017-05-01T00:00:00Z
2017-06-02T00:00:00Z

答案 2 :(得分:0)

另一种解决方案,使用Sql server

声明@FirstDOM日期,@ LastDOM日期时间

set @FirstDOM = (select dateadd(d,-1,dateadd(mm,datediff(m,0,getdate()),1 )))

SELECT CONVERT( varchar, @FirstDOM,101);