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