aboutsummaryrefslogtreecommitdiff
path: root/src/backend/parser/parse_collate.c
diff options
context:
space:
mode:
authorAmit Langote <amitlan@postgresql.org>2024-07-30 10:37:56 +0900
committerAmit Langote <amitlan@postgresql.org>2024-07-30 10:37:56 +0900
commit847ee701bd3a6d222ab8f67923e308ee1a70a2f8 (patch)
treedb89c0f7f2b2e6fc81a4308faa53e10edb8d30c7 /src/backend/parser/parse_collate.c
parentf208a16035fc5d18cee0e7e2fbf176616905f9b0 (diff)
downloadpostgresql-847ee701bd3a6d222ab8f67923e308ee1a70a2f8.tar.gz
postgresql-847ee701bd3a6d222ab8f67923e308ee1a70a2f8.zip
SQL/JSON: Some fixes to JsonBehavior expression casting
1. Remove the special case handling when casting the JsonBehavior expressions to types with typmod, like 86d33987 did for the casting of SQL/JSON constructor functions. 2. Fix casting for fixed-length character and bit string types by using assignment-level casts. This is again similar to what 86d33987 did, but for ON ERROR / EMPTY expressions. 3. Use runtime coercion for the boolean ON ERROR constants so that using fixed-length character string types, for example, for an EXISTS column doesn't cause a "value too long for type character(n)" when the parser tries to coerce the default ON ERROR value "false" to that type, that is, even when clause is not specified. 4. Simplify the conditions of when to use runtime coercion vs creating the cast expression in the parser itself. jsonb-valued expressions are now always coerced at runtime and boolean expressions too if the target type is a string type for the reasons mentioned above. New tests are from a patch that Jian He posted. Outputs of some existing tests change because the coercion now happens at runtime instead of at parse time. Reported-by: Jian He <jian.universality@gmail.com> Author: Jian He <jian.universality@gmail.com> Author: Amit Langote <amitlangote09@gmail.com> Discussion: https://postgr.es/m/CACJufxEo4sUjKCYtda0_qt9tazqqKPmF1cqhW9KBOUeJFqQd2g@mail.gmail.com Backpatch-through: 17
Diffstat (limited to 'src/backend/parser/parse_collate.c')
0 files changed, 0 insertions, 0 deletions