* range table.  An additional frammish is that dependencies on that
  * relation (or its component columns) will be marked with 'self_behavior',
  * whereas 'behavior' is used for everything else.
+ *
+ * NOTE: the caller should ensure that a whole-table dependency on the
+ * specified relation is created separately, if one is needed.  In particular,
+ * a whole-row Var "relation.*" will not cause this routine to emit any
+ * dependency item.  This is appropriate behavior for subexpressions of an
+ * ordinary query, so other cases need to cope as necessary.
  */
 void
 recordDependencyOnSingleRelExpr(const ObjectAddress *depender,
 
        /*
         * A whole-row Var references no specific columns, so adds no new
-        * dependency.
+        * dependency.  (We assume that there is a whole-table dependency
+        * arising from each underlying rangetable entry.  While we could
+        * record such a dependency when finding a whole-row Var that
+        * references a relation directly, it's quite unclear how to extend
+        * that to whole-row Vars for JOINs, so it seems better to leave the
+        * responsibility with the range table.  Note that this poses some
+        * risks for identifying dependencies of stand-alone expressions:
+        * whole-table references may need to be created separately.)
         */
        if (var->varattno == InvalidAttrNumber)
            return false;
 
 #include "nodes/makefuncs.h"
 #include "nodes/nodeFuncs.h"
 #include "optimizer/clauses.h"
-#include "optimizer/var.h"
 #include "parser/parser.h"
 #include "storage/bufmgr.h"
 #include "storage/lmgr.h"
            }
 
            /*
-            * It's possible for an index to not depend on any columns of the
-            * table at all, in which case we need to give it a dependency on
-            * the table as a whole; else it won't get dropped when the table
-            * is dropped.  This edge case is not totally useless; for
-            * example, a unique index on a constant expression can serve to
-            * prevent a table from containing more than one row.
+            * If there are no simply-referenced columns, give the index an
+            * auto dependency on the whole table.  In most cases, this will
+            * be redundant, but it might not be if the index expressions and
+            * predicate contain no Vars or only whole-row Vars.
             */
-           if (!have_simple_col &&
-            !contain_vars_of_level((Node *) indexInfo->ii_Expressions, 0) &&
-               !contain_vars_of_level((Node *) indexInfo->ii_Predicate, 0))
+           if (!have_simple_col)
            {
                referenced.classId = RelationRelationId;
                referenced.objectId = heapRelationId;
 
 static Node *processIndirection(Node *node, deparse_context *context,
                   bool printit);
 static void printSubscripts(ArrayRef *aref, deparse_context *context);
+static char *get_relation_name(Oid relid);
 static char *generate_relation_name(Oid relid, List *namespaces);
 static char *generate_function_name(Oid funcid, int nargs, List *argnames,
                       Oid *argtypes, bool *is_variadic);
 
    indexpr_item = list_head(indexprs);
 
-   context = deparse_context_for(get_rel_name(indrelid), indrelid);
+   context = deparse_context_for(get_relation_name(indrelid), indrelid);
 
    /*
     * Start the index definition.  Note that the index's name should never be
                if (conForm->conrelid != InvalidOid)
                {
                    /* relation constraint */
-                   context = deparse_context_for(get_rel_name(conForm->conrelid),
+                   context = deparse_context_for(get_relation_name(conForm->conrelid),
                                                  conForm->conrelid);
                }
                else
            gavealias = true;
        }
        else if (rte->rtekind == RTE_RELATION &&
-                strcmp(rte->eref->aliasname, get_rel_name(rte->relid)) != 0)
+                strcmp(rte->eref->aliasname, get_relation_name(rte->relid)) != 0)
        {
            /*
             * Apparently the rel has been renamed since the rule was made.
    return buf.data;
 }
 
+/*
+ * get_relation_name
+ *     Get the unqualified name of a relation specified by OID
+ *
+ * This differs from the underlying get_rel_name() function in that it will
+ * throw error instead of silently returning NULL if the OID is bad.
+ */
+static char *
+get_relation_name(Oid relid)
+{
+   char       *relname = get_rel_name(relid);
+
+   if (!relname)
+       elog(ERROR, "cache lookup failed for relation %u", relid);
+   return relname;
+}
+
 /*
  * generate_relation_name
  *     Compute the name to display for a relation specified by OID