joininfo.c

来自「postgresql8.3.4源码,开源数据库」· C语言 代码 · 共 101 行

C
101
字号
/*------------------------------------------------------------------------- * * joininfo.c *	  joininfo list manipulation routines * * Portions Copyright (c) 1996-2008, PostgreSQL Global Development Group * Portions Copyright (c) 1994, Regents of the University of California * * * IDENTIFICATION *	  $PostgreSQL: pgsql/src/backend/optimizer/util/joininfo.c,v 1.50 2008/01/01 19:45:50 momjian Exp $ * *------------------------------------------------------------------------- */#include "postgres.h"#include "optimizer/joininfo.h"#include "optimizer/pathnode.h"#include "optimizer/paths.h"/* * have_relevant_joinclause *		Detect whether there is a joinclause that can be used to join *		the two given relations. */boolhave_relevant_joinclause(PlannerInfo *root,						 RelOptInfo *rel1, RelOptInfo *rel2){	bool		result = false;	Relids		join_relids;	List	   *joininfo;	ListCell   *l;	join_relids = bms_union(rel1->relids, rel2->relids);	/*	 * We could scan either relation's joininfo list; may as well use the	 * shorter one.	 */	if (list_length(rel1->joininfo) <= list_length(rel2->joininfo))		joininfo = rel1->joininfo;	else		joininfo = rel2->joininfo;	foreach(l, joininfo)	{		RestrictInfo *rinfo = (RestrictInfo *) lfirst(l);		if (bms_is_subset(rinfo->required_relids, join_relids))		{			result = true;			break;		}	}	/*	 * We also need to check the EquivalenceClass data structure, which might	 * contain relationships not emitted into the joininfo lists.	 */	if (!result && rel1->has_eclass_joins && rel2->has_eclass_joins)		result = have_relevant_eclass_joinclause(root, rel1, rel2);	bms_free(join_relids);	return result;}/* * add_join_clause_to_rels *	  Add 'restrictinfo' to the joininfo list of each relation it requires. * * Note that the same copy of the restrictinfo node is linked to by all the * lists it is in.	This allows us to exploit caching of information about * the restriction clause (but we must be careful that the information does * not depend on context). * * 'restrictinfo' describes the join clause * 'join_relids' is the list of relations participating in the join clause *				 (there must be more than one) */voidadd_join_clause_to_rels(PlannerInfo *root,						RestrictInfo *restrictinfo,						Relids join_relids){	Relids		tmprelids;	int			cur_relid;	tmprelids = bms_copy(join_relids);	while ((cur_relid = bms_first_member(tmprelids)) >= 0)	{		RelOptInfo *rel = find_base_rel(root, cur_relid);		rel->joininfo = lappend(rel->joininfo, restrictinfo);	}	bms_free(tmprelids);}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?