首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在INSERT查询中使用WHERE子句?

如何在INSERT查询中使用WHERE子句?
EN

Stack Overflow用户
提问于 2016-06-03 13:45:22
回答 1查看 605关注 0票数 0

我有下表。

代码语言:javascript
复制
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列位于两个日期之间的值。例如:

代码语言:javascript
复制
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生成一系列年份。一切都没有成功。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-06-03 14:17:19

如果不想插入新行,则应该更新表。

代码语言:javascript
复制
UPDATE table_name
SET column1=value1,column2=value2,...
WHERE column_name BETWEEN value1 AND value2;

否则,你将有100毫安行;)

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/37616083

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档