Received: from malur.postgresql.org ([217.196.149.56]) by arkaria.postgresql.org with esmtps (TLS1.3:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.92) (envelope-from ) id 1p3ax2-0003hv-4W for pgsql-hackers@arkaria.postgresql.org; Fri, 09 Dec 2022 10:49:56 +0000 Received: from localhost ([127.0.0.1] helo=malur.postgresql.org) by malur.postgresql.org with esmtp (Exim 4.92) (envelope-from ) id 1p3ax0-0003gY-Vv for pgsql-hackers@arkaria.postgresql.org; Fri, 09 Dec 2022 10:49:54 +0000 Received: from magus.postgresql.org ([2a02:c0:301:0:ffff::29]) by malur.postgresql.org with esmtps (TLS1.3:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.92) (envelope-from ) id 1p3ax0-0003fj-NB for pgsql-hackers@lists.postgresql.org; Fri, 09 Dec 2022 10:49:54 +0000 Received: from out3-smtp.messagingengine.com ([66.111.4.27]) by magus.postgresql.org with esmtps (TLS1.3:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.92) (envelope-from ) id 1p3awy-0001CJ-15 for pgsql-hackers@postgresql.org; Fri, 09 Dec 2022 10:49:54 +0000 Received: from compute1.internal (compute1.nyi.internal [10.202.2.41]) by mailout.nyi.internal (Postfix) with ESMTP id 07C465C0166; Fri, 9 Dec 2022 05:49:50 -0500 (EST) Received: from mailfrontend2 ([10.202.2.163]) by compute1.internal (MEProxy); Fri, 09 Dec 2022 05:49:50 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d= messagingengine.com; h=cc:cc:content-transfer-encoding :content-type:date:date:feedback-id:feedback-id:from:from :in-reply-to:in-reply-to:message-id:mime-version:reply-to:sender :subject:subject:to:to:x-me-proxy:x-me-proxy:x-me-sender :x-me-sender:x-sasl-enc; s=fm2; t=1670582990; x=1670669390; bh=Z 0iAOb7SLmDf5RDhc4QXNRC8jplEhSaENyDkQgdTbyk=; b=DZuxfwECvT3LIkSP/ C1uuq/DrIQ42/4Pf+mHyefnJ95rcXjvJt75puq+fzsboG2ss7eiE7EBX9X2GdgFA oNhdUJ0Aucp65lMEqLXgNAFlcJ8df2c8m6SzAzkaXh78P4WzytC0zKAkMLq1lMGy JDEkZC9Z89H6hJYyN4JcPWaTfnFnXEf32tC2nYcBDMN44+J/4U9zKEXNl0l44RzG iPTBCpoLOxBwtAGYyp1qofs1XeUXtYnbh0kpRDTr44/NpPLwHm74gvshMH1Yv/iJ ufVqrk+nWHQtkvNFGE8GnM63rlVLA+jXvt0TcXjilypdb0cBtCZmcHnfCzqbASjw EsEiA== X-ME-Sender: X-ME-Received: X-ME-Proxy-Cause: gggruggvucftvghtrhhoucdtuddrgedvhedrvddvgddulecutefuodetggdotefrodftvf curfhrohhfihhlvgemucfhrghsthforghilhdpqfgfvfdpuffrtefokffrpgfnqfghnecu uegrihhlohhuthemuceftddtnecusecvtfgvtghiphhivghnthhsucdlqddutddtmdenuc fjughrpeffhffvvefukfggtggugfgjsehtkeertddttdejnecuhfhrohhmpeetlhhvrghr ohcujfgvrhhrvghrrgcuoegrlhhvhhgvrhhrvgesrghlvhhhrdhnohdqihhprdhorhhgqe enucggtffrrghtthgvrhhnpedvkedtffduffdtffffheffhfejjefhgfeiueeukeejkeff gfdufffhudffffeuveenucffohhmrghinhepvghnthgvrhhprhhishgvuggsrdgtohhmne cuvehluhhsthgvrhfuihiivgeptdenucfrrghrrghmpehmrghilhhfrhhomheprghlvhhh vghrrhgvsegrlhhvhhdrnhhoqdhiphdrohhrgh X-ME-Proxy: Feedback-ID: ia2694551:Fastmail Received: by mail.messagingengine.com (Postfix) with ESMTPA; Fri, 9 Dec 2022 05:49:49 -0500 (EST) Received: by perhan.alvh.no-ip.org (Postfix, from userid 1000) id 06B9DE98; Fri, 9 Dec 2022 11:49:48 +0100 (CET) Date: Fri, 9 Dec 2022 11:49:47 +0100 From: Alvaro Herrera To: Amit Langote Cc: Robert Haas , Jacob Champion , David Rowley , Tom Lane , PostgreSQL-development Subject: Re: generic plans and "initial" pruning Message-ID: <20221209104947.dkon6xtiaffainue@alvherre.pgsql> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: List-Id: List-Help: List-Subscribe: List-Post: List-Owner: List-Archive: Archived-At: Precedence: bulk On 2022-Dec-09, Amit Langote wrote: > On Fri, Dec 9, 2022 at 6:52 PM Alvaro Herrera wrote: > > Remind me again why is part_prune_results_list not part of struct > > CachedPlan then? I tried to understand that based on comments upthread, > > but I was unable to find anything. > > It used to be part of CachedPlan for a brief period of time (in patch > v12 I posted in [1]), but David, in his reply to [1], said he wasn't > so sure that it belonged there. I'm not sure I necessarily agree with that. I'll have a look at v12 to try and understand what was David so unhappy about. > > (My first reaction to your above comment was "well, rename GetCachedPlan > > then, maybe to GetRunnablePlan", but then I'm wondering if CachedPlan is > > in any way a structure that must be "immutable" in the way parser output > > is. Looking at the comment at the top of plancache.c it appears to me > > that it isn't, but maybe I'm missing something.) > > CachedPlan *is* supposed to be read-only per the comment above > CachedPlanSource definition: > > * ...If we are using a generic > * cached plan then it is meant to be re-used across multiple executions, so > * callers must always treat CachedPlans as read-only. I read that as implying that the part_prune_results_list must remain intact as long as no invalidations occur. Does part_prune_result_list really change as a result of something other than a sinval event? Keep in mind that if a sinval message that touches one of the relations in the plan arrives, then we'll discard it and generate it afresh. I don't see that the part_prune_results_list would change otherwise, but maybe I misunderstand? > FYI, there was even an idea of putting a PartitionPruneResults for a > given PlannedStmt into the PlannedStmt itself [2], but PlannedStmt is > supposed to be read-only too [3]. Hmm, I'm not familiar with PlannedStmt lifetime, but I'm definitely not betting that Tom is wrong about this. > Maybe we need some new overarching context when invoking plancache, if > Portal can't already be it, whose struct can be passed to > GetCachedPlan() to put the pruning results in? Perhaps, > GetRunnablePlan() that you floated could be a wrapper for > GetCachedPlan(), owning that new context. Perhaps that is a solution. I'm not sure. -- Álvaro Herrera PostgreSQL Developer — https://www.EnterpriseDB.com/ "Uno puede defenderse de los ataques; contra los elogios se esta indefenso"