「postgre」INT最大值

一般现在时间戳用INTEGER整型即可,但INT最大长度为21多一点,也就是再过不到20年,就会溢出,所以建议时间戳用INT8类型,同样,数据量可能超过21亿的也应该使用INT8自增,如下:

-- DROP TABLE IF EXISTS location;
create table location (
id SERIAL8 PRIMARY KEY,
ip_int INT8 UNIQUE NOT NULL DEFAULT 0, -- IP整型化
ip VARCHAR(20) NOT NULL DEFAULT '', -- IP地址
province_id INTEGER NOT NULL DEFAULT 0, -- 省份ID
city_id INTEGER NOT NULL DEFAULT 0, -- 城市ID
province_name VARCHAR(20) NOT NULL DEFAULT '', -- 省份名称
city_name VARCHAR(20) NOT NULL DEFAULT '', -- 城市名称
last_date INTEGER NOT NULL DEFAULT CAST(TO_CHAR(NOW(), 'yyyymmdd') AS INTEGER), -- 修改日期,格式20060102表示2006年1月2日
last_time INT8 NOT NULL DEFAULT EXTRACT(EPOCH FROM NOW()) -- 修改时间戳,单位秒
);

猜你喜欢

转载自www.cnblogs.com/ftrako/p/9713655.html
今日推荐