mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-24 01:29:19 +03:00 
			
		
		
		
	Add error_on_null(), checking if the input is the null value
This polymorphic function produces an error if the input value is detected as being the null value; otherwise it returns the input value unchanged. This function can for example become handy in SQL function bodies, to enforce that exactly one row was returned. Author: Joel Jacobson <joel@compiler.org> Reviewed-by: Vik Fearing <vik@postgresfriends.org> Reviewed-by: Michael Paquier <michael@paquier.xyz> Discussion: https://postgr.es/m/ece8c6d1-2ab1-45d5-ba12-8dec96fc8886@app.fastmail.com Discussion: https://postgr.es/m/de94808d-ed58-4536-9e28-e79b09a534c7@app.fastmail.com
This commit is contained in:
		| @@ -599,6 +599,28 @@ SELECT NOT(ROW(table.*) IS NOT NULL) FROM TABLE; -- detect at least one null in | |||||||
|      </thead> |      </thead> | ||||||
|  |  | ||||||
|      <tbody> |      <tbody> | ||||||
|  |       <row> | ||||||
|  |        <entry role="func_table_entry"><para role="func_signature"> | ||||||
|  |         <indexterm> | ||||||
|  |          <primary>error_on_null</primary> | ||||||
|  |         </indexterm> | ||||||
|  |         <function>error_on_null</function> ( <type>anyelement</type> ) | ||||||
|  |         <returnvalue>anyelement</returnvalue> | ||||||
|  |        </para> | ||||||
|  |        <para> | ||||||
|  |         Checks if the input is the null value, generating an error if so; | ||||||
|  |         otherwise, returns the input. | ||||||
|  |        </para> | ||||||
|  |        <para> | ||||||
|  |         <literal>error_on_null(42)</literal> | ||||||
|  |         <returnvalue>42</returnvalue> | ||||||
|  |        </para> | ||||||
|  |        <para> | ||||||
|  |         <literal>error_on_null(row(null,null))</literal> | ||||||
|  |         <returnvalue>(,)</returnvalue> | ||||||
|  |        </para></entry> | ||||||
|  |       </row> | ||||||
|  |  | ||||||
|       <row> |       <row> | ||||||
|        <entry role="func_table_entry"><para role="func_signature"> |        <entry role="func_table_entry"><para role="func_signature"> | ||||||
|         <indexterm> |         <indexterm> | ||||||
|   | |||||||
| @@ -186,6 +186,20 @@ pg_num_nonnulls(PG_FUNCTION_ARGS) | |||||||
| 	PG_RETURN_INT32(nargs - nulls); | 	PG_RETURN_INT32(nargs - nulls); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * error_on_null() | ||||||
|  |  *	Check if the input is the NULL value | ||||||
|  |  */ | ||||||
|  | Datum | ||||||
|  | pg_error_on_null(PG_FUNCTION_ARGS) | ||||||
|  | { | ||||||
|  | 	if (PG_ARGISNULL(0)) | ||||||
|  | 		ereport(ERROR, | ||||||
|  | 				(errcode(ERRCODE_NULL_VALUE_NOT_ALLOWED), | ||||||
|  | 				 errmsg("null value not allowed"))); | ||||||
|  |  | ||||||
|  | 	PG_RETURN_DATUM(PG_GETARG_DATUM(0)); | ||||||
|  | } | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * current_database() |  * current_database() | ||||||
|   | |||||||
| @@ -12543,6 +12543,9 @@ | |||||||
| { oid => '6292', descr => 'aggregate transition function', | { oid => '6292', descr => 'aggregate transition function', | ||||||
|   proname => 'any_value_transfn', prorettype => 'anyelement', |   proname => 'any_value_transfn', prorettype => 'anyelement', | ||||||
|   proargtypes => 'anyelement anyelement', prosrc => 'any_value_transfn' }, |   proargtypes => 'anyelement anyelement', prosrc => 'any_value_transfn' }, | ||||||
|  | { oid => '8488', descr => 'check if input is the null value', | ||||||
|  |   proname => 'error_on_null', proisstrict => 'f', prorettype => 'anyelement', | ||||||
|  |   proargtypes => 'anyelement', prosrc => 'pg_error_on_null' }, | ||||||
|  |  | ||||||
| { oid => '6321', descr => 'list of available WAL summary files', | { oid => '6321', descr => 'list of available WAL summary files', | ||||||
|   proname => 'pg_available_wal_summaries', prorows => '100', proretset => 't', |   proname => 'pg_available_wal_summaries', prorows => '100', proretset => 't', | ||||||
|   | |||||||
| @@ -177,6 +177,37 @@ ERROR:  function num_nulls() does not exist | |||||||
| LINE 1: SELECT num_nulls(); | LINE 1: SELECT num_nulls(); | ||||||
|                ^ |                ^ | ||||||
| DETAIL:  No function of that name accepts the given number of arguments. | DETAIL:  No function of that name accepts the given number of arguments. | ||||||
|  | -- | ||||||
|  | -- error_on_null() | ||||||
|  | -- | ||||||
|  | SELECT error_on_null(1); | ||||||
|  |  error_on_null  | ||||||
|  | --------------- | ||||||
|  |              1 | ||||||
|  | (1 row) | ||||||
|  |  | ||||||
|  | SELECT error_on_null(NULL::int); | ||||||
|  | ERROR:  null value not allowed | ||||||
|  | SELECT error_on_null(NULL::int[]); | ||||||
|  | ERROR:  null value not allowed | ||||||
|  | SELECT error_on_null('{1,2,NULL,3}'::int[]); | ||||||
|  |  error_on_null  | ||||||
|  | --------------- | ||||||
|  |  {1,2,NULL,3} | ||||||
|  | (1 row) | ||||||
|  |  | ||||||
|  | SELECT error_on_null(ROW(1,NULL::int)); | ||||||
|  |  error_on_null  | ||||||
|  | --------------- | ||||||
|  |  (1,) | ||||||
|  | (1 row) | ||||||
|  |  | ||||||
|  | SELECT error_on_null(ROW(NULL,NULL)); | ||||||
|  |  error_on_null  | ||||||
|  | --------------- | ||||||
|  |  (,) | ||||||
|  | (1 row) | ||||||
|  |  | ||||||
| -- | -- | ||||||
| -- canonicalize_path() | -- canonicalize_path() | ||||||
| -- | -- | ||||||
|   | |||||||
| @@ -77,6 +77,17 @@ SELECT num_nulls(VARIADIC '{}'::int[]); | |||||||
| SELECT num_nonnulls(); | SELECT num_nonnulls(); | ||||||
| SELECT num_nulls(); | SELECT num_nulls(); | ||||||
|  |  | ||||||
|  | -- | ||||||
|  | -- error_on_null() | ||||||
|  | -- | ||||||
|  |  | ||||||
|  | SELECT error_on_null(1); | ||||||
|  | SELECT error_on_null(NULL::int); | ||||||
|  | SELECT error_on_null(NULL::int[]); | ||||||
|  | SELECT error_on_null('{1,2,NULL,3}'::int[]); | ||||||
|  | SELECT error_on_null(ROW(1,NULL::int)); | ||||||
|  | SELECT error_on_null(ROW(NULL,NULL)); | ||||||
|  |  | ||||||
| -- | -- | ||||||
| -- canonicalize_path() | -- canonicalize_path() | ||||||
| -- | -- | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user