mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	Fix error message for ALTER CONSTRAINT ... NOT VALID
Trying to alter a constraint so that it becomes NOT VALID results in an error that assumes the constraint is a foreign key. This is potentially wrong, so give a more generic error message. While at it, give CREATE CONSTRAINT TRIGGER a better error message as well. Co-authored-by: jian he <jian.universality@gmail.com> Co-authored-by: Fujii Masao <masao.fujii@oss.nttdata.com> Co-authored-by: Álvaro Herrera <alvherre@kurilemu.de> Co-authored-by: Amul Sul <sulamul@gmail.com> Discussion: https://postgr.es/m/CACJufxHSp2puxP=q8ZtUGL1F+heapnzqFBZy5ZNGUjUgwjBqTQ@mail.gmail.com
This commit is contained in:
		| @@ -2668,6 +2668,12 @@ alter_table_cmd: | ||||
| 						c->alterDeferrability = true; | ||||
| 					if ($4 & CAS_NO_INHERIT) | ||||
| 						c->alterInheritability = true; | ||||
| 					/* handle unsupported case with specific error message */ | ||||
| 					if ($4 & CAS_NOT_VALID) | ||||
| 						ereport(ERROR, | ||||
| 								errcode(ERRCODE_FEATURE_NOT_SUPPORTED), | ||||
| 								errmsg("constraints cannot be altered to be NOT VALID"), | ||||
| 								parser_errposition(@4)); | ||||
| 					processCASbits($4, @4, "FOREIGN KEY", | ||||
| 									&c->deferrable, | ||||
| 									&c->initdeferred, | ||||
|   | ||||
		Reference in New Issue
	
	Block a user