]> git.ipfire.org Git - thirdparty/postgresql.git/commit
Record dependencies on graph labels and properties
authorPeter Eisentraut <peter@eisentraut.org>
Tue, 9 Jun 2026 10:55:47 +0000 (12:55 +0200)
committerPeter Eisentraut <peter@eisentraut.org>
Tue, 9 Jun 2026 10:55:47 +0000 (12:55 +0200)
commit9d8cdcbe0c8aee743e29079bdb2e4b5eeae4c70e
tree87c49d67c4efa64aebe9307d8c5544d22d2aa1d0
parentbd4bd30ce6a7f08e95390c3fa068f2bfbe9fcee8
Record dependencies on graph labels and properties

A view definition with GRAPH_TABLE depends upon the property graph it
references as well as the properties and labels referenced in it.  We
recorded the dependency on the property graph, but did not record
dependency on labels and properties.  This allowed properties or
labels referenced by a view to be dropped, resulting in a cache lookup
error when such a view was accessed.  Fix this bug by handling
GraphPropertyRef and GraphLabelRef in find_expr_references_walker().
The dependency on the data type of property does not need to be
recorded separately as it is recorded indirectly via a dependency on
the property graph property itself.

Note that a property or a label associated with individual elements
can still be dropped as long as there are other elements that are
associated with that property or label, since they do not lead to
dropping the property or the label from the property graph altogether.

Reported-by: Man Zeng <zengman@halodbtech.com>
Author: Ayush Tiwari <ayushtiwari.slg01@gmail.com>
Author: Ashutosh Bapat <ashutosh.bapat.oss@gmail.com>
Reviewed-by: Junwang Zhao <zhjwpku@gmail.com>
Discussion: https://www.postgresql.org/message-id/flat/tencent_43D9888041FA4FDE498C7BF1%40qq.com
src/backend/catalog/dependency.c
src/include/catalog/catversion.h
src/test/regress/expected/graph_table.out
src/test/regress/sql/graph_table.sql