PostgreSQL 9.2 の JSON データ型のサイズの制限を知っている人はいますか?
質問する
49293 次
2 に答える
92
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です。
于 2012-09-28T03:23:47.143 に答える