我有下表。
CREATE TABLE public.ad
(
id integer NOT NULL DEFAULT nextval('ad_id_seq'::regclass),
uuid uuid NOT NULL DEFAULT uuid_generate_v4(),
created_at timestamp without time zone NOT NULL,
updated_at timestamp without time zone NOT NULL,
cmdb_id integer,
platform character varying(100),
bidfloor numeric(15,6),
views integer NOT NULL DEFAULT 1,
year integer,
month integer,
day integer,
CONSTRAINT ad_pkey PRIMARY KEY (id),
CONSTRAINT ad_cmdb_id_foreign FOREIGN KEY (cmdb_id)
REFERENCES public.cmdb (id) MATCH SIMPLE
ON UPDATE NO ACTION ON DELETE NO ACTION,
CONSTRAINT ad_id_unique UNIQUE (uuid)
)
WITH (
OIDS=FALSE
);在没有太多细节的情况下,这张表记录了全国各地电子屏幕上广告的所有要求和印象。此表还用于生成报告,由+- 5千万条记录组成。
目前,报告是在created_at时间戳上过滤的。您可以想象,使用+- 5000万条记录,即使在created_at列上有索引,查询也会变得缓慢。报告是通过选择要请求系统UI上的数据的日期来生成的。
“年”、“月”和“日”是我刚刚添加的新列,以提高报告的效率。我希望系统不对日期进行索引,而是对一年、月和日进行索引,所有这些值都是独立的。
新添加的列仍然是空的。我希望运行一个查询,该查询插入created_at列位于两个日期之间的值。例如:
INSERT INTO ad (year) VALUES (2016) WHERE created_at BETWEEN '2016-01-01 00:00:00' AND '2016-12-31 23:59:59';当然这不管用。我似乎在互联网上找不到插入语句使用where子句的任何东西。我还尝试使用子查询和WITH clausule在2012年至2020年期间使用generate_series生成一系列年份。一切都没有成功。
发布于 2016-06-03 14:17:19
如果不想插入新行,则应该更新表。
UPDATE table_name
SET column1=value1,column2=value2,...
WHERE column_name BETWEEN value1 AND value2;否则,你将有100毫安行;)
https://stackoverflow.com/questions/37616083
复制相似问题