]> granicus.if.org Git - postgresql/blob - src/include/optimizer/planmain.h
New cost model for planning, incorporating a penalty for random page
[postgresql] / src / include / optimizer / planmain.h
1 /*-------------------------------------------------------------------------
2  *
3  * planmain.h
4  *        prototypes for various files in optimizer/plan
5  *
6  *
7  * Portions Copyright (c) 1996-2000, PostgreSQL, Inc
8  * Portions Copyright (c) 1994, Regents of the University of California
9  *
10  * $Id: planmain.h,v 1.38 2000/02/15 20:49:26 tgl Exp $
11  *
12  *-------------------------------------------------------------------------
13  */
14 #ifndef PLANMAIN_H
15 #define PLANMAIN_H
16
17 #include "nodes/plannodes.h"
18 #include "nodes/relation.h"
19
20 /*
21  * prototypes for plan/planmain.c
22  */
23 extern Plan *query_planner(Query *root, List *tlist, List *qual,
24                                                    double tuple_fraction);
25
26 /*
27  * prototypes for plan/createplan.c
28  */
29 extern Plan *create_plan(Query *root, Path *best_path);
30 extern SeqScan *make_seqscan(List *qptlist, List *qpqual, Index scanrelid);
31 extern Sort *make_sort(List *tlist, Oid nonameid, Plan *lefttree,
32                   int keycount);
33 extern Agg *make_agg(List *tlist, List *qual, Plan *lefttree);
34 extern Group *make_group(List *tlist, bool tuplePerGroup, int ngrp,
35                    AttrNumber *grpColIdx, Plan *lefttree);
36 extern Noname *make_noname(List *tlist, List *pathkeys, Plan *subplan);
37 extern Unique *make_unique(List *tlist, Plan *lefttree, List *distinctList);
38 extern Result *make_result(List *tlist, Node *resconstantqual, Plan *subplan);
39
40 /*
41  * prototypes for plan/initsplan.c
42  */
43 extern void make_var_only_tlist(Query *root, List *tlist);
44 extern void add_restrict_and_join_to_rels(Query *root, List *clauses);
45 extern void add_missing_rels_to_query(Query *root);
46
47 /*
48  * prototypes for plan/setrefs.c
49  */
50 extern void set_plan_references(Plan *plan);
51 extern List *join_references(List *clauses, List *outer_tlist,
52                                                          List *inner_tlist, Index acceptable_rel);
53 extern void fix_opids(Node *node);
54
55 /*
56  * prep/prepkeyset.c
57  */
58 extern void transformKeySetQuery(Query *origNode);
59
60 #endif   /* PLANMAIN_H */