mirror of
https://github.com/postgres/postgres.git
synced 2025-07-03 20:02:46 +03:00
Make SQL/JSON error code names match SQL standard
There were some minor differences that didn't seem necessary. Discussion: https://www.postgresql.org/message-id/flat/86b67eef-bb26-c97d-3e35-64f1fbd4f9fe%402ndquadrant.com
This commit is contained in:
@ -337,7 +337,7 @@ jsonb_path_match(PG_FUNCTION_ARGS)
|
||||
|
||||
if (!silent)
|
||||
ereport(ERROR,
|
||||
(errcode(ERRCODE_SINGLETON_JSON_ITEM_REQUIRED),
|
||||
(errcode(ERRCODE_SINGLETON_SQL_JSON_ITEM_REQUIRED),
|
||||
errmsg("single boolean result is expected")));
|
||||
|
||||
PG_RETURN_NULL();
|
||||
@ -602,7 +602,7 @@ executeItemOptUnwrapTarget(JsonPathExecContext *cxt, JsonPathItem *jsp,
|
||||
return jperError;
|
||||
|
||||
ereport(ERROR,
|
||||
(errcode(ERRCODE_JSON_MEMBER_NOT_FOUND), \
|
||||
(errcode(ERRCODE_SQL_JSON_MEMBER_NOT_FOUND), \
|
||||
errmsg("JSON object does not contain key \"%s\"",
|
||||
pnstrdup(key.val.string.val,
|
||||
key.val.string.len))));
|
||||
@ -614,7 +614,7 @@ executeItemOptUnwrapTarget(JsonPathExecContext *cxt, JsonPathItem *jsp,
|
||||
{
|
||||
Assert(found);
|
||||
RETURN_ERROR(ereport(ERROR,
|
||||
(errcode(ERRCODE_JSON_MEMBER_NOT_FOUND),
|
||||
(errcode(ERRCODE_SQL_JSON_MEMBER_NOT_FOUND),
|
||||
errmsg("jsonpath member accessor can only be applied to an object"))));
|
||||
}
|
||||
break;
|
||||
@ -643,7 +643,7 @@ executeItemOptUnwrapTarget(JsonPathExecContext *cxt, JsonPathItem *jsp,
|
||||
res = executeNextItem(cxt, jsp, NULL, jb, found, true);
|
||||
else if (!jspIgnoreStructuralErrors(cxt))
|
||||
RETURN_ERROR(ereport(ERROR,
|
||||
(errcode(ERRCODE_JSON_ARRAY_NOT_FOUND),
|
||||
(errcode(ERRCODE_SQL_JSON_ARRAY_NOT_FOUND),
|
||||
errmsg("jsonpath wildcard array accessor can only be applied to an array"))));
|
||||
break;
|
||||
|
||||
@ -691,7 +691,7 @@ executeItemOptUnwrapTarget(JsonPathExecContext *cxt, JsonPathItem *jsp,
|
||||
index_from > index_to ||
|
||||
index_to >= size))
|
||||
RETURN_ERROR(ereport(ERROR,
|
||||
(errcode(ERRCODE_INVALID_JSON_SUBSCRIPT),
|
||||
(errcode(ERRCODE_INVALID_SQL_JSON_SUBSCRIPT),
|
||||
errmsg("jsonpath array subscript is out of bounds"))));
|
||||
|
||||
if (index_from < 0)
|
||||
@ -748,7 +748,7 @@ executeItemOptUnwrapTarget(JsonPathExecContext *cxt, JsonPathItem *jsp,
|
||||
else if (!jspIgnoreStructuralErrors(cxt))
|
||||
{
|
||||
RETURN_ERROR(ereport(ERROR,
|
||||
(errcode(ERRCODE_JSON_ARRAY_NOT_FOUND),
|
||||
(errcode(ERRCODE_SQL_JSON_ARRAY_NOT_FOUND),
|
||||
errmsg("jsonpath array accessor can only be applied to an array"))));
|
||||
}
|
||||
break;
|
||||
@ -802,7 +802,7 @@ executeItemOptUnwrapTarget(JsonPathExecContext *cxt, JsonPathItem *jsp,
|
||||
{
|
||||
Assert(found);
|
||||
RETURN_ERROR(ereport(ERROR,
|
||||
(errcode(ERRCODE_JSON_OBJECT_NOT_FOUND),
|
||||
(errcode(ERRCODE_SQL_JSON_OBJECT_NOT_FOUND),
|
||||
errmsg("jsonpath wildcard member accessor can only be applied to an object"))));
|
||||
}
|
||||
break;
|
||||
@ -932,7 +932,7 @@ executeItemOptUnwrapTarget(JsonPathExecContext *cxt, JsonPathItem *jsp,
|
||||
{
|
||||
if (!jspIgnoreStructuralErrors(cxt))
|
||||
RETURN_ERROR(ereport(ERROR,
|
||||
(errcode(ERRCODE_JSON_ARRAY_NOT_FOUND),
|
||||
(errcode(ERRCODE_SQL_JSON_ARRAY_NOT_FOUND),
|
||||
errmsg("jsonpath item method .%s() can only be applied to an array",
|
||||
jspOperationName(jsp->type)))));
|
||||
break;
|
||||
@ -986,7 +986,7 @@ executeItemOptUnwrapTarget(JsonPathExecContext *cxt, JsonPathItem *jsp,
|
||||
|
||||
if (have_error)
|
||||
RETURN_ERROR(ereport(ERROR,
|
||||
(errcode(ERRCODE_NON_NUMERIC_JSON_ITEM),
|
||||
(errcode(ERRCODE_NON_NUMERIC_SQL_JSON_ITEM),
|
||||
errmsg("jsonpath item method .%s() can only be applied to a numeric value",
|
||||
jspOperationName(jsp->type)))));
|
||||
res = jperOk;
|
||||
@ -1007,7 +1007,7 @@ executeItemOptUnwrapTarget(JsonPathExecContext *cxt, JsonPathItem *jsp,
|
||||
|
||||
if (have_error || isinf(val))
|
||||
RETURN_ERROR(ereport(ERROR,
|
||||
(errcode(ERRCODE_NON_NUMERIC_JSON_ITEM),
|
||||
(errcode(ERRCODE_NON_NUMERIC_SQL_JSON_ITEM),
|
||||
errmsg("jsonpath item method .%s() can only be applied to a numeric value",
|
||||
jspOperationName(jsp->type)))));
|
||||
|
||||
@ -1020,7 +1020,7 @@ executeItemOptUnwrapTarget(JsonPathExecContext *cxt, JsonPathItem *jsp,
|
||||
|
||||
if (res == jperNotFound)
|
||||
RETURN_ERROR(ereport(ERROR,
|
||||
(errcode(ERRCODE_NON_NUMERIC_JSON_ITEM),
|
||||
(errcode(ERRCODE_NON_NUMERIC_SQL_JSON_ITEM),
|
||||
errmsg("jsonpath item method .%s() can only be applied to a string or numeric value",
|
||||
jspOperationName(jsp->type)))));
|
||||
|
||||
@ -1504,14 +1504,14 @@ executeBinaryArithmExpr(JsonPathExecContext *cxt, JsonPathItem *jsp,
|
||||
if (JsonValueListLength(&lseq) != 1 ||
|
||||
!(lval = getScalar(JsonValueListHead(&lseq), jbvNumeric)))
|
||||
RETURN_ERROR(ereport(ERROR,
|
||||
(errcode(ERRCODE_SINGLETON_JSON_ITEM_REQUIRED),
|
||||
(errcode(ERRCODE_SINGLETON_SQL_JSON_ITEM_REQUIRED),
|
||||
errmsg("left operand of jsonpath operator %s is not a single numeric value",
|
||||
jspOperationName(jsp->type)))));
|
||||
|
||||
if (JsonValueListLength(&rseq) != 1 ||
|
||||
!(rval = getScalar(JsonValueListHead(&rseq), jbvNumeric)))
|
||||
RETURN_ERROR(ereport(ERROR,
|
||||
(errcode(ERRCODE_SINGLETON_JSON_ITEM_REQUIRED),
|
||||
(errcode(ERRCODE_SINGLETON_SQL_JSON_ITEM_REQUIRED),
|
||||
errmsg("right operand of jsonpath operator %s is not a single numeric value",
|
||||
jspOperationName(jsp->type)))));
|
||||
|
||||
@ -1579,7 +1579,7 @@ executeUnaryArithmExpr(JsonPathExecContext *cxt, JsonPathItem *jsp,
|
||||
continue; /* skip non-numerics processing */
|
||||
|
||||
RETURN_ERROR(ereport(ERROR,
|
||||
(errcode(ERRCODE_JSON_NUMBER_NOT_FOUND),
|
||||
(errcode(ERRCODE_SQL_JSON_NUMBER_NOT_FOUND),
|
||||
errmsg("operand of unary jsonpath operator %s is not a numeric value",
|
||||
jspOperationName(jsp->type)))));
|
||||
}
|
||||
@ -1701,7 +1701,7 @@ executeNumericItemMethod(JsonPathExecContext *cxt, JsonPathItem *jsp,
|
||||
|
||||
if (!(jb = getScalar(jb, jbvNumeric)))
|
||||
RETURN_ERROR(ereport(ERROR,
|
||||
(errcode(ERRCODE_NON_NUMERIC_JSON_ITEM),
|
||||
(errcode(ERRCODE_NON_NUMERIC_SQL_JSON_ITEM),
|
||||
errmsg("jsonpath item method .%s() can only be applied to a numeric value",
|
||||
jspOperationName(jsp->type)))));
|
||||
|
||||
@ -1760,7 +1760,7 @@ executeKeyValueMethod(JsonPathExecContext *cxt, JsonPathItem *jsp,
|
||||
|
||||
if (JsonbType(jb) != jbvObject || jb->type != jbvBinary)
|
||||
RETURN_ERROR(ereport(ERROR,
|
||||
(errcode(ERRCODE_JSON_OBJECT_NOT_FOUND),
|
||||
(errcode(ERRCODE_SQL_JSON_OBJECT_NOT_FOUND),
|
||||
errmsg("jsonpath item method .%s() can only be applied to an object",
|
||||
jspOperationName(jsp->type)))));
|
||||
|
||||
@ -2190,7 +2190,7 @@ getArrayIndex(JsonPathExecContext *cxt, JsonPathItem *jsp, JsonbValue *jb,
|
||||
if (JsonValueListLength(&found) != 1 ||
|
||||
!(jbv = getScalar(JsonValueListHead(&found), jbvNumeric)))
|
||||
RETURN_ERROR(ereport(ERROR,
|
||||
(errcode(ERRCODE_INVALID_JSON_SUBSCRIPT),
|
||||
(errcode(ERRCODE_INVALID_SQL_JSON_SUBSCRIPT),
|
||||
errmsg("jsonpath array subscript is not a single numeric value"))));
|
||||
|
||||
numeric_index = DirectFunctionCall2(numeric_trunc,
|
||||
@ -2202,7 +2202,7 @@ getArrayIndex(JsonPathExecContext *cxt, JsonPathItem *jsp, JsonbValue *jb,
|
||||
|
||||
if (have_error)
|
||||
RETURN_ERROR(ereport(ERROR,
|
||||
(errcode(ERRCODE_INVALID_JSON_SUBSCRIPT),
|
||||
(errcode(ERRCODE_INVALID_SQL_JSON_SUBSCRIPT),
|
||||
errmsg("jsonpath array subscript is out of integer range"))));
|
||||
|
||||
return jperOk;
|
||||
|
Reference in New Issue
Block a user