mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-21 02:52:47 +03:00 
			
		
		
		
	Improve ordering for \dAo and \dAp psql commands
This commit changes ORDER BY clause for \dAo and \dAp psql commands in the following way. * Operators for the same types are grouped together. * Same-class operators and procedures are listed before cross-class operators and procedures. Modification of ORDER BY clause for \dAp required removing DISTINCT clause, which doesn't seem to affect anything. Discussion: https://postgr.es/m/20200511210856.GA18368%40alvherre.pgsql Author: Alvaro Herrera revised by me Reviewed-by: Alexander Korotkov, Nikita Glukhov
This commit is contained in:
		| @@ -6288,7 +6288,11 @@ listOpFamilyOperators(const char *access_method_pattern, | |||||||
| 		processSQLNamePattern(pset.db, &buf, family_pattern, have_where, false, | 		processSQLNamePattern(pset.db, &buf, family_pattern, have_where, false, | ||||||
| 							  "nsf.nspname", "of.opfname", NULL, NULL); | 							  "nsf.nspname", "of.opfname", NULL, NULL); | ||||||
|  |  | ||||||
| 	appendPQExpBufferStr(&buf, "ORDER BY 1, 2, o.amopstrategy, 3;"); | 	appendPQExpBufferStr(&buf, "ORDER BY 1, 2,\n" | ||||||
|  | 						 "  o.amoplefttype = o.amoprighttype DESC,\n" | ||||||
|  | 						 "  pg_catalog.format_type(o.amoplefttype, NULL),\n" | ||||||
|  | 						 "  pg_catalog.format_type(o.amoprighttype, NULL),\n" | ||||||
|  | 						 "  o.amopstrategy;"); | ||||||
|  |  | ||||||
| 	res = PSQLexec(buf.data); | 	res = PSQLexec(buf.data); | ||||||
| 	termPQExpBuffer(&buf); | 	termPQExpBuffer(&buf); | ||||||
| @@ -6327,7 +6331,7 @@ listOpFamilyProcedures(const char *access_method_pattern, | |||||||
| 	initPQExpBuffer(&buf); | 	initPQExpBuffer(&buf); | ||||||
|  |  | ||||||
| 	printfPQExpBuffer(&buf, | 	printfPQExpBuffer(&buf, | ||||||
| 					  "SELECT DISTINCT\n" | 					  "SELECT\n" | ||||||
| 					  "  am.amname AS \"%s\",\n" | 					  "  am.amname AS \"%s\",\n" | ||||||
| 					  "  CASE\n" | 					  "  CASE\n" | ||||||
| 					  "    WHEN pg_catalog.pg_opfamily_is_visible(of.oid)\n" | 					  "    WHEN pg_catalog.pg_opfamily_is_visible(of.oid)\n" | ||||||
| @@ -6360,8 +6364,9 @@ listOpFamilyProcedures(const char *access_method_pattern, | |||||||
| 		processSQLNamePattern(pset.db, &buf, family_pattern, have_where, false, | 		processSQLNamePattern(pset.db, &buf, family_pattern, have_where, false, | ||||||
| 							  "ns.nspname", "of.opfname", NULL, NULL); | 							  "ns.nspname", "of.opfname", NULL, NULL); | ||||||
|  |  | ||||||
| 	appendPQExpBufferStr(&buf, | 	appendPQExpBufferStr(&buf, "ORDER BY 1, 2,\n" | ||||||
| 						 "ORDER BY 1, 2, 3, 4, 5;"); | 						 "  ap.amproclefttype = ap.amprocrighttype DESC,\n" | ||||||
|  | 						 "  3, 4, 5;"); | ||||||
|  |  | ||||||
| 	res = PSQLexec(buf.data); | 	res = PSQLexec(buf.data); | ||||||
| 	termPQExpBuffer(&buf); | 	termPQExpBuffer(&buf); | ||||||
|   | |||||||
| @@ -4952,16 +4952,31 @@ List of access methods | |||||||
|  btree | integer_ops     | smallint, integer, bigint |  btree | integer_ops     | smallint, integer, bigint | ||||||
| (1 row) | (1 row) | ||||||
|  |  | ||||||
| \dAo brin uuid_minmax_ops | \dAo+ btree float_ops | ||||||
|   List of operators of operator families |                                 List of operators of operator families | ||||||
|   AM  |  Opfamily Name  |    Operator      |   AM   | Opfamily Name |                Operator                 | Strategy | Purpose | Sort opfamily  | ||||||
| ------+-----------------+----------------- | -------+---------------+-----------------------------------------+----------+---------+--------------- | ||||||
|  brin | uuid_minmax_ops | < (uuid, uuid) |  btree | float_ops     | < (double precision, double precision)  |        1 | search  |  | ||||||
|  brin | uuid_minmax_ops | <= (uuid, uuid) |  btree | float_ops     | <= (double precision, double precision) |        2 | search  |  | ||||||
|  brin | uuid_minmax_ops | = (uuid, uuid) |  btree | float_ops     | = (double precision, double precision)  |        3 | search  |  | ||||||
|  brin | uuid_minmax_ops | >= (uuid, uuid) |  btree | float_ops     | >= (double precision, double precision) |        4 | search  |  | ||||||
|  brin | uuid_minmax_ops | > (uuid, uuid) |  btree | float_ops     | > (double precision, double precision)  |        5 | search  |  | ||||||
| (5 rows) |  btree | float_ops     | < (real, real)                          |        1 | search  |  | ||||||
|  |  btree | float_ops     | <= (real, real)                         |        2 | search  |  | ||||||
|  |  btree | float_ops     | = (real, real)                          |        3 | search  |  | ||||||
|  |  btree | float_ops     | >= (real, real)                         |        4 | search  |  | ||||||
|  |  btree | float_ops     | > (real, real)                          |        5 | search  |  | ||||||
|  |  btree | float_ops     | < (double precision, real)              |        1 | search  |  | ||||||
|  |  btree | float_ops     | <= (double precision, real)             |        2 | search  |  | ||||||
|  |  btree | float_ops     | = (double precision, real)              |        3 | search  |  | ||||||
|  |  btree | float_ops     | >= (double precision, real)             |        4 | search  |  | ||||||
|  |  btree | float_ops     | > (double precision, real)              |        5 | search  |  | ||||||
|  |  btree | float_ops     | < (real, double precision)              |        1 | search  |  | ||||||
|  |  btree | float_ops     | <= (real, double precision)             |        2 | search  |  | ||||||
|  |  btree | float_ops     | = (real, double precision)              |        3 | search  |  | ||||||
|  |  btree | float_ops     | >= (real, double precision)             |        4 | search  |  | ||||||
|  |  btree | float_ops     | > (real, double precision)              |        5 | search  |  | ||||||
|  | (20 rows) | ||||||
|  |  | ||||||
| \dAo * pg_catalog.jsonb_path_ops | \dAo * pg_catalog.jsonb_path_ops | ||||||
|    List of operators of operator families |    List of operators of operator families | ||||||
| @@ -4972,15 +4987,19 @@ List of access methods | |||||||
|  gin | jsonb_path_ops | @@ (jsonb, jsonpath) |  gin | jsonb_path_ops | @@ (jsonb, jsonpath) | ||||||
| (3 rows) | (3 rows) | ||||||
|  |  | ||||||
| \dAp brin uuid_minmax_ops | \dAp btree float_ops | ||||||
|                           List of procedures of operator families |                            List of procedures of operator families | ||||||
|   AM  | Operator family | Left arg type | Right arg type | Number |       Proc name         |   AM   | Operator family |  Left arg type   |  Right arg type  | Number |      Proc name       | ||||||
| ------+-----------------+---------------+----------------+--------+------------------------ | -------+-----------------+------------------+------------------+--------+--------------------- | ||||||
|  brin | uuid_minmax_ops | uuid          | uuid           |      1 | brin_minmax_opcinfo |  btree | float_ops       | double precision | double precision |      1 | btfloat8cmp | ||||||
|  brin | uuid_minmax_ops | uuid          | uuid           |      2 | brin_minmax_add_value |  btree | float_ops       | double precision | double precision |      2 | btfloat8sortsupport | ||||||
|  brin | uuid_minmax_ops | uuid          | uuid           |      3 | brin_minmax_consistent |  btree | float_ops       | double precision | double precision |      3 | in_range | ||||||
|  brin | uuid_minmax_ops | uuid          | uuid           |      4 | brin_minmax_union |  btree | float_ops       | real             | real             |      1 | btfloat4cmp | ||||||
| (4 rows) |  btree | float_ops       | real             | real             |      2 | btfloat4sortsupport | ||||||
|  |  btree | float_ops       | double precision | real             |      1 | btfloat84cmp | ||||||
|  |  btree | float_ops       | real             | double precision |      1 | btfloat48cmp | ||||||
|  |  btree | float_ops       | real             | double precision |      3 | in_range | ||||||
|  | (8 rows) | ||||||
|  |  | ||||||
| \dAp * pg_catalog.uuid_ops | \dAp * pg_catalog.uuid_ops | ||||||
|                         List of procedures of operator families |                         List of procedures of operator families | ||||||
|   | |||||||
| @@ -1203,7 +1203,7 @@ drop role regress_partitioning_role; | |||||||
| \dAc brin pg*.oid* | \dAc brin pg*.oid* | ||||||
| \dAf spgist | \dAf spgist | ||||||
| \dAf btree int4 | \dAf btree int4 | ||||||
| \dAo brin uuid_minmax_ops | \dAo+ btree float_ops | ||||||
| \dAo * pg_catalog.jsonb_path_ops | \dAo * pg_catalog.jsonb_path_ops | ||||||
| \dAp brin uuid_minmax_ops | \dAp btree float_ops | ||||||
| \dAp * pg_catalog.uuid_ops | \dAp * pg_catalog.uuid_ops | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user