sql >> Databáze >  >> RDS >> PostgreSQL

Limit velikosti datového typu JSON v PostgreSQL

Při pohledu na zdroj pro 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));
}

Aktualizace pro PostgreSQL 9.3.5:

Kód se v json_in změnil funkce, ale interní reprezentace json je stále text:

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);
}

Zdá se tedy, že alespoň prozatím json je stejný jako text datový typ, ale s ověřením JSON. text maximální velikost datového typu je 1 GB.



  1. Typy textových, ntextových a obrazových dat> nelze porovnávat ani třídit, s výjimkou použití operátoru IS NULL nebo LIKE>

  2. SQL Server ekvivalent funkce WM_CONCAT

  3. Změny datového konektoru v roce 2020

  4. Java Stored Procedure vs PL/SQL Stored Procedure