未来的sql时间戳?

时间:2014-10-09 22:01:56

标签: java sql

使用sql语法可以在TimeStamp列中比当前时间提前60分钟创建一个值吗?或者你是否需要获取当前时间,将其变为字符串,将60分钟(1小时)添加到时间值,然后插入?

由于

3 个答案:

答案 0 :(得分:1)

Transact-SQL:SELECT DATEADD(HOUR, 1, CURRENT_TIMESTAMP)其中CURRENT_TIMESTAMP可以是time,date,smalldatetime,datetime,datetime2或datetimeoffset,然后解析为DateTime。

MYSQL:SELECT DATE_ADD(SYSDATE(), INTERVAL 1 HOUR);

如果你正在使用PostgreSQL并希望复制这个函数,建议使用以下方法创建这种类型的函数:

CREATE OR REPLACE FUNCTION dateadd(character varying, integer, date) 
RETURNS date AS
$BODY$
DECLARE
p_Interval ALIAS FOR $1;
p_N ALIAS FOR $2;
p_Date ALIAS FOR $3;

BEGIN
if p_Interval = 'm' then
return p_Date + cast(p_N || ' months' as interval);
elseif p_Interval = 'y' then
return p_Date + cast(p_N || ' years' as interval);
elseif p_Interval = 's' then
return p_Date + cast(p_N || ' seconds' as interval);
elseif p_Interval = 'min' then
return p_Date + cast(p_N || ' minutes' as interval);
else
raise exception 'dateadd interval parameter not supported';
return null;
end if;
END;
$BODY$
LANGUAGE 'plpgsql';

答案 1 :(得分:1)

您应该可以使用MySQL中的DATE_ADD函数来执行此操作。

SELECT DATE_ADD(SYSDATE(), INTERVAL 1 HOUR);

请注意SYSDATE()

  

'YYYY-MM-DD HH:MM:SS'YYYYMMDDHHMMSS.uuuuuu格式返回当前日期和时间,具体取决于函数是在字符串还是数字上下文中使用。

答案 2 :(得分:0)

如果是MS sql server,这应该可行

select getdate()                -- current datetime
select dateadd(mi,60,getdate()) -- current datetime + 60 seconds