PostgreSQL 提供了一个名为 json
和 jsonb
的数据类型,用于存储 JSON 格式的数据。这两种类型在存储和性能方面有所不同:
json
类型存储的是文本格式的 JSON 数据,存储后数据不会进行预格式化处理,因此查询时需要重新解析整个文本。jsonb
类型存储的是二进制格式的 JSON 数据,在存储时数据会进行预格式化处理,因此查询时可以直接从已经解析的格式中读取,减少了解析开销,通常性能更好。
官方文档中关于 json
类型的说明:
https://www.postgresql.org/docs/current/datatype-json.html
以下是一个简单的例子,演示如何在 PostgreSQL 中创建一个包含 json
类型字段的表,以及如何插入和查询 json
类型的数据:
-- 创建一个包含 json 类型字段的表
CREATE TABLE example_table (
id serial PRIMARY KEY,
data json
);
-- 插入 json 数据
INSERT INTO example_table (data)
VALUES ('{"name": "John", "age": 30}');
-- 查询 json 数据
SELECT * FROM example_table;
-- 查询 json 字段中的特定元素
SELECT data->>'name' FROM example_table;
在实际应用中,推荐使用 jsonb
类型,因为它提供了更好的性能和更多的功能。