PostgreSQL 9.0.x中不推荐使用Datetime变量类型吗?

Edw*_*win 3 postgresql datetime timestamp

我正在查询外部API,并希望在转移到生产之前测试测试服务器上的数据插入.

目前,我正在尝试在Postgres的shell中执行以下语句:

CREATE TABLE referrals (client_id VARCHAR(36), device_id VARCHAR(100), conversion_time DATETIME, acquisition_cost MONEY);
Run Code Online (Sandbox Code Playgroud)

但它一直在失败DATETIME.

由于这不起作用,会是时间戳吗?如果是这样,我如何修改时间戳的默认行为以采取预先格式化的日期和时间?

PS如果在Database Admins StackExchange上更好地询问,请标记而不是downvote.

Erw*_*ter 7

CREATE TABLE referrals (
   client_id text, 
   device_id text, 
   conversion_time timestamp,
   acquisition_cost money
);
Run Code Online (Sandbox Code Playgroud)

您无需添加without time zone,这是默认设置.

我使用text示例中的类型而不是varchar长度修饰符,因为这通常是更好的选择.你varchar(n)当然可以使用,没问题.

日期/时间戳值的接受字符串输入格式取决于您的区域设置.要确保正确解释特定格式,而不考虑区域设置,您可以使用to_dateto_timestamp:

SELECT to_timestamp('05 Dec 2000', 'DD Mon YYYY')
Run Code Online (Sandbox Code Playgroud)

更多内容在精细手册的数据类型格式化功能一章中.