![]() | |
![]() |
| | Thread Tools | Display Modes |
#1
| |||
| |||
|
|
Dear patchers, please find attached my third patch submission for adding new aggregate functions. This new version adds a note and some indexes in the documentation about sql standard names for bool_and and bool_or, as suggested by Robert Treat. It also fixes conflicts created by the removal of shameful aclitem accessors. The added aggregates are: (1) boolean-and and boolean-or aggregates named bool_and and bool_or. they (SHOULD;-) correspond to standard sql every and some/any aggregates. they do not have the right name as there is a problem with the standard and the parser for some/any. Tom also think that the standard name is misleading because NULL are ignored. (2) bitwise integer aggregates named bit_and and bit_or for int2, int4, int8 and bit types. They are not standard, but I find them useful. I needed them once. The patches adds: - 2 new very short strict functions for boolean aggregates in src/backed/utils/adt/bool.c, src/include/utils/builtins.h and src/include/catalog/pg_proc.h - the new aggregates declared in src/include/catalog/pg_proc.h and src/include/catalog/pg_aggregate.h - some documentation and validation about these new aggregates. It also updates the catalog version. It validates for me. Have a nice day, -- Fabien Coelho - coelho (AT) cri (DOT) ensmp.fr |
|
---------------------------(end of broadcast)--------------------------- TIP 8: explain analyze is your friend |
#2
| ||||
| ||||
|
|
(1) boolean-and and boolean-or aggregates named bool_and and bool_or. they (SHOULD;-) correspond to standard sql every and some/any aggregates. they do not have the right name as there is a problem with the standard and the parser for some/any. Tom also think that the standard name is misleading because NULL are ignored. |
|
+ /* EVERY aggregate implementation conforming to SQL 2003 standard. + * must be strict. + */ |
|
+ PG_FUNCTION_INFO_V1(booland_statefunc); |
|
+ /* what about every? */ + DATA(insert OID = 2517 ( bool_and PGNSP PGUID 12 t f f f i 1 16 "16" _null_ aggregate_dummy - _null_ )); + DESCR("boolean-and aggregate"); + /* what about any/some? */ |
#3
| ||||
| ||||
|
|
As I understand it, there's an ambiguity issue with SOME/ANY, but not with EVERY. If so, can we implement EVERY per-spec at least? It's okay if we just add EVERY as an alias for BOOL_AND for the sake of homogeneity. |
|
+ /* EVERY aggregate implementation conforming to SQL 2003 standard. + * must be strict. + */ This comment is misleading if we don't actually provide an implementation of EVERY that conforms to spec. There's a similar comment WRT to SOME/ANY. |
|
+ PG_FUNCTION_INFO_V1(booland_statefunc); Not needed for builtin functions (they are assumed to be V1). |
|
+ /* what about every? */ + DATA(insert OID = 2517 ( bool_and PGNSP PGUID 12 t f f f i 1 16 "16" _null_ aggregate_dummy - _null_ )); + DESCR("boolean-and aggregate"); + /* what about any/some? */ Seems these questions should be removed, no? |
![]() |
| Thread Tools | |
| Display Modes | |
| |