从sql server获取两个日期之间的数据

Posted

技术标签:

【中文标题】从sql server获取两个日期之间的数据【英文标题】:Get data between two date from sql server 【发布时间】:2021-05-19 03:50:36 【问题描述】:

我想使用 mssql 和 nodejs 中的 sequelize 查询从 sql server 获取两个日期之间的所有数据。

开始和结束日期来自 react frontend with axios.post。 例如开始日期是2021-01-04T08:53:00.000Z,结束日期是2021-01-05T21:00:00.000Z

app.post('/getData', function (req, res) 
  let startTime=req.body.start
  let endTime=req.body.end

  sequelize.query(` select Date_Time from S001T01  where Date_Time between $startTime and $endTime`, 
    type: sequelize.QueryTypes.SELECT
  ).then(result => 
    console.log(result)
)

);

它返回许多错误,其中一个是 UnhandledPromiseRejectionWarning: SequelizeDatabaseError: Invalid column name '2021-01-05T21:00:00.000Z 23:59:00'.

在表格查看器中显示的 Date_Time 列中

我不知道该怎么办。

感谢您的帮助。

【问题讨论】:

在sql中,双引号用于标识符,单引号用于字符串和日期 我更改了查询,但仍有错误。 Executing (default): select Date_Time from S001T01 where Date_Time between 2021-01-04T08:53:00.000Zand 2021-01-04T21:00:00.000Z (node:2576) UnhandledPromiseRejectionWarning: SequelizeDatabaseError: Incorrect syntax near 'T08:'. 【参考方案1】:

您的日期时间格式可能有误。 2021-01-05T21:00:00.000Z 23:59:00 不对应传统的ISO 8601。

如果您想要 2021-01-04T08:53:00.000Z2021-01-05T21:00:00.000Z 之间的所有条目,您的 SQL 查询应如下所示:

select Date_Time from S001T01  where Date_Time between 2021-01-04T08:53:00.000Z and 2021-01-05T21:00:00.000Z

您还应该考虑在串联时使用修改后的日期时间。

也许类似的东西应该可以完成这项工作:

var dt = new Date();
dt.setHours( dt.getHours() + 2 );

希望对你有帮助。

【讨论】:

嘿,感谢您的回答,但我仍然收到此错误。 Executing (default): select Date_Time from S001T01 where Date_Time between 2021-01-04T08:53:00.000Z and 2021-01-05T21:00:00.000Z (node:12684) UnhandledPromiseRejectionWarning: SequelizeDatabaseError: Incorrect syntax near 'T08:'. 您是否尝试过另一种日期时间格式,例如YYYY-MM-DD HH:mm:ss,而不是 ISO 8601 格式?我可以在论坛上看到,为了在两个日期之间进行查询,格式应该像我上面提到的那样。 SELECT * FROM T_DATES_TDT WHERE TDT_DATE BETWEEN '2006-04-8' AND '2006-04-8 23:59:59.999' 是的,我试过select * from S001T01 where Date_Time between 2021-01-04 21:44:00 and 2021-01-04 22:03:00,但结果是一样的。它总是抛出`'21'附近的语法不正确。` 在日期值之间加上引号可能没问题。 select * from S001T01 where Date_Time between '2021-01-04 21:44:00' and '2021-01-04 22:03:00'forum link

以上是关于从sql server获取两个日期之间的数据的主要内容,如果未能解决你的问题,请参考以下文章

在 sql server 2008 中的两个日期之间获取 Id

sql server 中两个日期之间的年份以及每个日期在 sql server 中的开始和结束日期

sqlserver数据怎么查询两个时间之间的数据

如何通过 SQL 语句从两个特定日期(由用户指定)之间的数据库表中获取数据?

试图找到如何在两个日期之间从 SQL 数据库中提取数据 [重复]

在 bigquery 标准 sql 上提取两个日期之间的小时数