有人知道 PostgreSQL 9.2 中 JSON 数据类型的大小有什么限制吗?
最佳答案
查看 PostgreSQL 9.2.1 的源代码:
Source: postgresql-9.2.1\src\backend\utils\adt\json.c:
/*
* Input.
*/
Datum
json_in(PG_FUNCTION_ARGS)
{
char *text = PG_GETARG_CSTRING(0);
json_validate_cstring(text);
/* Internal representation is the same as text, for now */
PG_RETURN_TEXT_P(cstring_to_text(text));
}
PostgreSQL 9.3.5 更新:
json_in
函数中的代码发生了变化,但是json内部表示还是文本:
Source: postgresql-9.3.5\src\backend\utils\adt\json.c:
/*
* Input.
*/
Datum
json_in(PG_FUNCTION_ARGS)
{
char *json = PG_GETARG_CSTRING(0);
text *result = cstring_to_text(json);
JsonLexContext *lex;
/* validate it */
lex = makeJsonLexContext(result, false);
pg_parse_json(lex, &nullSemAction);
/* Internal representation is the same as text, for now */
PG_RETURN_TEXT_P(result);
}
因此,至少目前看来,json
与 text
数据类型相同,但具有 JSON 验证。 text
数据类型的最大大小为 1GB .
https://stackoverflow.com/questions/12632871/