Hom*_*lli 1 postgresql plpgsql
我正在尝试dateadd()使用PL/PgSQL 编写一个函数.我希望能够添加从秒到几年到日期/时间戳的任何内容.拼凑了一个函数(来自网上获得的片段等),并提出了这个"实现":
CREATE OR REPLACE FUNCTION dateadd(diffType VARCHAR(15), incrementValue int, inputDate timestamp) RETURNS timestamp AS $$
DECLARE
YEAR_CONST Char(15) := 'year';
MONTH_CONST Char(15) := 'month';
DAY_CONST Char(15) := 'day';
HOUR_CONST Char(15) := 'hour';
MIN_CONST Char(15) := 'min';
SEC_CONST Char(15) := 'sec';
dateTemp Date;
intervals interval;
BEGIN
IF lower($1) = lower(YEAR_CONST) THEN
select cast(cast(incrementvalue as character varying) || ' year' as interval) into intervals;
ELSEIF lower($1) = lower(MONTH_CONST) THEN
select cast(cast(incrementvalue as character varying) || ' months' as interval) into intervals;
ELSEIF lower($1) = lower(DAY_CONST) THEN
select cast(cast(incrementvalue as character varying) || ' day' as interval) into intervals;
ELSEIF lower($1) = lower(HOUR_CONST) THEN
select cast(cast(incrementvalue as character varying) || ' hour' as interval) into intervals;
ELSEIF lower($1) = lower(MIN_CONST) THEN
select cast(cast(incrementvalue as character varying) || ' minute' as interval) into intervals;
ELSEIF lower($1) = lower(SEC_CONST) THEN
select cast(cast(incrementvalue as character varying) || ' second' as interval) into intervals;
END IF;
dateTemp:= inputdate + intervals;
RETURN dateTemp;
END;
$$ IMMUTABLE LANGUAGE plpgsql;
Run Code Online (Sandbox Code Playgroud)
但是,当我尝试使用该函数时,我收到以下错误:
template1=# select dateadd('hour', 1, getdate());
ERROR: function dateadd(unknown, integer, timestamp with time zone) does not exist
LINE 1: select dateadd('hour', 1, getdate());
^
HINT: No function matches the given name and argument types. You might need to add explicit type casts.
template1=#
Run Code Online (Sandbox Code Playgroud)
为什么PG找不到这个功能?
我在Ubuntu 12.0.4 LTS上运行PG 9.3
你会踢自己:错误行(和接下来的几行)之间的差异是你不小心在错误的地方添加了一个下划线:
你有:
HOUR_CONST_Char(15):='小时';
它应该是:
HOUR_CONST Char(15):='hour';
编辑
更新后的问题是Postgres稍微挑剔的类型系统:你的getdate()功能正在返回timestamp with time zone,但你dateadd接受了timestamp(即timestamp without time zone).使用Postgres简写为演员value::type,这应该工作(SQLFiddle演示,now()代替使用getdate())
select dateadd('hour', 1, getdate()::timestamp);
Run Code Online (Sandbox Code Playgroud)
但是,您还有其他一些奇怪的类型选择:
Char(15),但不是15个字符长,所以将填充空格; 你可能应该使用VarChar(15),甚至只是text(与MS SQL不同,在Postgres中,所有字符串都是动态地存储在页外,而a VarChar本质上只是text一个最大长度约束).Date,而不是Timestamp,因此会将输入截断为日期部分,没有时间.最后,我会注意到一个基本优化:你不需要lower()你的常量,因为你已经知道它们是小写的.:)
| 归档时间: |
|
| 查看次数: |
35771 次 |
| 最近记录: |