diff --git a/doc/src/sgml/ref/comment.sgml b/doc/src/sgml/ref/comment.sgml
index ae4640b6235..115889ef58f 100644
--- a/doc/src/sgml/ref/comment.sgml
+++ b/doc/src/sgml/ref/comment.sgml
@@ -80,14 +80,16 @@ COMMENT ON
Description
- COMMENT stores a comment about a database object.
+ COMMENT stores, replaces, or removes the comment on a
+ database object.
- Only one comment string is stored for each object, so to modify a comment,
- issue a new COMMENT command for the same object. To remove a
- comment, write NULL in place of the text string.
- Comments are automatically dropped when their object is dropped.
+ Only one comment string is stored for each object. Issuing a new
+ COMMENT command for the same object replaces the
+ existing comment. Specifying NULL or an empty
+ string ('') removes the comment. Comments are
+ automatically dropped when their object is dropped.
@@ -265,7 +267,8 @@ COMMENT ON
string_literal
- The new comment contents, written as a string literal.
+ The new comment contents, written as a string literal. An empty string
+ ('') removes the comment.
@@ -274,7 +277,7 @@ COMMENT ON
NULL
- Write NULL to drop the comment.
+ Write NULL to remove the comment.
@@ -361,6 +364,7 @@ COMMENT ON TRANSFORM FOR hstore LANGUAGE plpythonu IS 'Transform between hstore
COMMENT ON TRIGGER my_trigger ON my_table IS 'Used for RI';
COMMENT ON TYPE complex IS 'Complex number data type';
COMMENT ON VIEW my_view IS 'View of departmental costs';
+COMMENT ON VIEW my_view IS NULL;
diff --git a/src/test/regress/expected/create_index.out b/src/test/regress/expected/create_index.out
index be80774dd4f..ad8de5b3a6f 100644
--- a/src/test/regress/expected/create_index.out
+++ b/src/test/regress/expected/create_index.out
@@ -30,6 +30,20 @@ COMMENT ON INDEX six_wrong IS 'bad index';
ERROR: relation "six_wrong" does not exist
COMMENT ON INDEX six IS 'good index';
COMMENT ON INDEX six IS NULL;
+SELECT obj_description('six'::regclass, 'pg_class') IS NULL AS six_comment_is_null;
+ six_comment_is_null
+---------------------
+ t
+(1 row)
+
+COMMENT ON INDEX six IS 'add the comment back';
+COMMENT ON INDEX six IS ''; -- empty string removes the comment, same as NULL
+SELECT obj_description('six'::regclass, 'pg_class') IS NULL AS six_comment_is_null;
+ six_comment_is_null
+---------------------
+ t
+(1 row)
+
--
-- BTREE ascending/descending cases
--
diff --git a/src/test/regress/sql/create_index.sql b/src/test/regress/sql/create_index.sql
index b4c49405ae2..47d6124aebb 100644
--- a/src/test/regress/sql/create_index.sql
+++ b/src/test/regress/sql/create_index.sql
@@ -42,6 +42,10 @@ CREATE INDEX six ON shighway USING btree (name text_ops);
COMMENT ON INDEX six_wrong IS 'bad index';
COMMENT ON INDEX six IS 'good index';
COMMENT ON INDEX six IS NULL;
+SELECT obj_description('six'::regclass, 'pg_class') IS NULL AS six_comment_is_null;
+COMMENT ON INDEX six IS 'add the comment back';
+COMMENT ON INDEX six IS ''; -- empty string removes the comment, same as NULL
+SELECT obj_description('six'::regclass, 'pg_class') IS NULL AS six_comment_is_null;
--
-- BTREE ascending/descending cases