67

PostgreSQL 9.2 の JSON データ型のサイズの制限を知っている人はいますか?

4

2 に答える 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 に答える