@@ -60,6 +60,7 @@ PlannedStmt *sr_planner(Query *parse,
6060bool find_ok = false;
6161LOCKMODE heap_lock = AccessShareLock ;
6262Oid query_index_rel_oid ;
63+ Oid sr_plans_oid ;
6364IndexScanDesc query_index_scan ;
6465ScanKeyData key ;
6566
@@ -81,7 +82,14 @@ PlannedStmt *sr_planner(Query *parse,
8182sr_query_walker ((Query * )parse ,NULL );
8283
8384sr_plans_table_rv = makeRangeVar ("public" ,"sr_plans" ,-1 );
84- sr_plans_heap = heap_openrv (sr_plans_table_rv ,heap_lock );
85+ /* First check existance of "sr_plans" table */
86+ sr_plans_oid = RangeVarGetRelid (sr_plans_table_rv ,heap_lock , true);
87+ if (!OidIsValid (sr_plans_oid ))
88+ /* Just call standard_planner() if table doesn't exist. */
89+ return standard_planner (parse ,cursorOptions ,boundParams );
90+
91+ /* Table "sr_plans" exists */
92+ sr_plans_heap = heap_open (sr_plans_oid ,NoLock );
8593
8694#if PG_VERSION_NUM >=90600
8795query_index_rel_oid = DatumGetObjectId (DirectFunctionCall1 (to_regclass ,PointerGetDatum (cstring_to_text ("sr_plans_query_hash_idx" ))));
@@ -90,6 +98,7 @@ PlannedStmt *sr_planner(Query *parse,
9098#endif
9199if (query_index_rel_oid == InvalidOid )
92100{
101+ heap_close (sr_plans_heap ,heap_lock );
93102elog (WARNING ,"Not found sr_plans_query_hash_idx index" );
94103return standard_planner (parse ,cursorOptions ,boundParams );
95104}