- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我有一个如下所述的 SQL 表,其中每 30 分钟包含 1 条记录以及其他一些列 -
ID | dt
1 | 2015-08-08 23:30:00.000
2 | 2015-08-08 23:00:00.000
3 | 2015-08-08 22:30:00.000
4 | 2015-08-08 22:00:00.000
5 | 2015-08-08 21:30:00.000
我运行以下查询以从 SQL Server 获取昨天的所有记录。
select ID, dt from tbl1
WHERE DATEADD(dd, DATEDIFF(dd, 0, dt), 0) >= DATEADD(dd, DATEDIFF(dd, 0, @StartDate), 0)
and DATEADD(dd, DATEDIFF(dd, 0, dt), 0) <= DATEADD(dd, DATEDIFF(dd, 0, @EndDate), 0)
当我将参数作为 StartDate = '2015-08-08 12:00:00' and EndDate='2015-08-08 06:30:00'
发送时,查询运行正常并返回结果但是当 StartDate = '2015-08-08 12:00:00' and EndDate='2015-08-08 06:00:00'
时它不返回任何记录或者当 EndDate 明确小于“2015-08-08 06:30:00”时。我跑了SELECT GETDATE()
在服务器上,它返回与服务器时钟显示的时间相同的时间。
编辑
代码通过每 30 分钟运行一次的 Windows 服务执行。该应用程序假设在凌晨 1:00 运行,检索上次日期的记录并执行操作,但如前所述,记录仅在早上 6:30 后返回,目前我只能在早上 7 点运行该服务而不是凌晨 1 点。
当我将服务设置为从我的本地计算机运行时,它在凌晨 1 点运行良好并返回结果,但在生产服务器上,它在早上 6:30 之前不返回任何记录。
我不知道为什么会出现这种差异。任何帮助表示赞赏。
如果您需要更多说明,我会在这里回答。
最佳答案
您最初问过为什么当 @StartDate
为“2015-08-08 12:00:00”且 @EndDate
为“2015-08”时没有收到任何记录-08 06:30:00'。请理解,在这种情况下,@StartDate
在 @EndDate
之后,因此您永远不会获得大于 @StartDate< 的
且小于 dt
值@EndDate
。
话虽如此,您显然想使用 @StartDate
和 @EndDate
参数的 FLOOR(即忽略时间部分)而不是原始使用它们,那又怎样你可以这样做:
@StartDate
和 @EndDate
参数@EndDate
上加一天tbl
中选择所有记录,其中 dt
在修改后的 @StartDate
和 @EndDate
之间
@EndDate
的确切值此示例假定您的代码作为存储过程的一部分被调用,并将选择大于或等于 @StartDate
但小于 @EndDate
的所有日期(您不需要对 dt
应用相同的转换):
-- Swap @StartDate and @EndDate values if need be
IF(@StartDate > @EndDate)
BEGIN
DECLARE @TempDate DATETIME;
SET @TempDate = @StartDate;
SET @StartDate = @EndDate;
SET @EndDate = @TempDate;
END;
-- Deliberately set @EndDate to one more than specified
-- Example case:
-- Before After
-- @StartDate '2015-08-08 06:30:00' => '2015-08-08 00:00:00'
-- @EndDate '2015-08-08 12:00:00' => '2015-08-09 00:00:00'
SET @StartDate = dateadd(day,datediff(day,0,@StartDate),0);
SET @EndDate = dateadd(day,datediff(day,0,@StartDate)+1,0);
-- Query
select ID, dt from tbl1
WHERE dt >= @StartDate
and dt < @EndDate
关于c# - SQL Server 中奇怪的时差,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31912494/
我正在尝试创建一个程序,该程序采用两个军事时间的差异并获取其时差。 示例: **上午到下午** 时间 1:0900 时间 2:1730 时差:8 小时 30 分钟 **下午到上午** 时间 1:120
我正在尝试计算两个时间字段之间的时间差异。由于这些字段只是没有日期的时间,因此我无法使用 timestampdiff,因此我使用 timediff() 或 subtime() 。唯一的问题是,当第二次
我试图简单地计算 5:30:00 - 2:30:00 的时差。显然这应该导致 3:00:00 但是当我在控制台中执行以下代码时 var a = new Date(0,0,0,5,30,0) var b
我试图在 C 中区分两个日期,但我收到这样的输出: future date: 18-11-2013 22:8 current date: 18-11-2013 22:8 这是我的代码: #includ
我正在尝试计算截至上午 00:00 的剩余分钟数。 DELIMITER // CREATE PROCEDURE midnightCountdown() BEGIN SELECT TIME_FORMAT
我正在尝试使用 postgresql 从表(login_history as t1)中检索以分钟为单位的时差。 当我尝试这段代码时 ((date_part('hour', timestamp '201
欢迎!我有问题想问你。我正在 Laravel 5.2 中为自己编写飞行日志。在公式中,我将有起飞时间和到达时间,但我不知道如何在 laravel 中计算时间差并将其自动传递到数据库。因此,最简单的方法
我已经查看了有关此主题的其他问答,但没有找到任何帮助。 我的应用记录比赛结果并保存到文件。 第一次点击它会写入当前时间,当运行者完成后,它会再次记录当前时间。 如何计算这两个时间以获得比赛时间? 这是
我有非常简单的代码来计算两次之间的差异: import java.text.SimpleDateFormat; import java.util.Date; import java.util.Greg
在 Python 中比较 2 次以加快测试一段代码的正确方法是什么?我尝试阅读 API 文档。我不确定我是否理解 timedelta。 到目前为止,我有这个代码: from datetime impo
这个问题非常类似于Best timestamp format for CSV/Excel? : 我正在写一个 CSV 文件。我需要编写至少精确到秒,最好精确到毫秒的时间跨度(又名时差)。 CSV 文件
我试图通过输入时间格式计算12小时内的java时差,当我输入开始时间11:58:10 pm和结束时间12:02时效果很好:15 点。但当我输入 12:00:00 am 和 12:00:00 pm 时,
因此,对于一项作业,我们必须编写一个程序,该程序需要两次军事时间,并显示它们之间的小时和分钟差异,假设第一次是两次时间中较早的一次。我们不允许使用 if 语句,因为它在技术上尚未被学习。这是运行时的示
我必须为分布在全局各地的所有人员制定 24 小时时间表。 例如,某人可以在 10:00 开始工作,并在 19:00 结束工作,因此获得时差非常简单,因为结束时间和开始时间在同一天。但是,如果我有人在
使用 ntp 时间时,(英国)返回的时间总是比实际时间少一小时。例如:现在时间是 13.35 但当我说日期时,它返回 12.35。有什么建议? try: c = ntplib.
我有一个应用程序,它在登录时记录时间,在退出时记录退出时间。 我的表有 IN_TIME 和 OUT_TIME 这些列中的数据示例: IN_TIME = 16:06:46 结束时间 = 16:08:07
我使用 $_POST 将变量从 ajax 表单发布到 php 服务器端我有两个变量,时间和金额。在服务器中,我有一个 MYSQL 数据库,其中包含 _end_time (数据类型:时间)和金额(数据类
我正在尝试计算在这里工作的人的轮类模式,从结束时间减去开始时间在大多数情况下都有效,但如果他们通宵工作则不行。例如,从 10pm 到 6am 工作的人将显示为: 22:00 - 06:00 我希望返回
任何人都可以提供一个 Excel 方程来计算两个 UTC 时间戳之间的差异。 UTC 时间戳的格式为 yyyymmddhhmmssZ(例如 20160127175049Z)。时间戳之间的差异最多为几个
我在大学学习一门名为“智能机器”的类(class)。我们向我们介绍了 3 种强化学习方法,并通过这些方法我们获得了何时使用它们的直觉,我引用: Q-Learning - 当 MDP 无法解决时最好。
我是一名优秀的程序员,十分优秀!