JSON 和 JSONB 的区别

JSON 和 JSONB 的区别

存储方式:

  • JSON: 以纯文本格式存储数据。每次读取数据时,需要进行文本解析。
  • JSONB: 以二进制格式存储数据。在写入时进行解析并优化数据格式,读取时无需再次解析。

性能:

  • JSON: 由于是纯文本存储,每次读取时需要解析文本,读取性能较低。但写入性能较高,因为不需要额外的转换。
  • JSONB: 由于以二进制格式存储,读取性能较高,适合频繁的读取操作。写入时需要转换为二进制格式,写入性能可能略低。

灵活性:

  • JSON: 非常灵活,适用于写操作频繁但读操作不频繁的场景。
  • JSONB: 适用于读操作频繁、需要高效查询和复杂操作的场景。

功能:

  • JSON: 支持基本的 JSON 操作,如插入、删除和简单查询,但不支持高级操作。
  • JSONB: 支持更多高级操作,如索引、函数和操作符,可以更高效地进行复杂查询。

JSON 示例

使用 Jackson 库处理 JSON 数据。

Maven 依赖

xml 复制代码
<dependency>
    <groupId>com.fasterxml.jackson.core</groupId>
    <artifactId>jackson-databind</artifactId>
    <version>2.12.3</version>
</dependency>

Java 代码

java 复制代码
import com.fasterxml.jackson.databind.ObjectMapper;

public class JsonExample {
    public static void main(String[] args) {
        ObjectMapper objectMapper = new ObjectMapper();
        
        // 创建 Java 对象
        User user = new User(1, "Alice", "alice@example.com");

        try {
            // 将 Java 对象转换为 JSON 字符串
            String jsonString = objectMapper.writeValueAsString(user);
            System.out.println("JSON String: " + jsonString);

            // 将 JSON 字符串解析为 Java 对象
            User parsedUser = objectMapper.readValue(jsonString, User.class);
            System.out.println("Parsed User: " + parsedUser);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

class User {
    private int id;
    private String name;
    private String email;

    // 构造函数、getter 和 setter

    public User(int id, String name, String email) {
        this.id = id;
        this.name = name;
        this.email = email;
    }

    // toString 方法
    @Override
    public String toString() {
        return "User{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", email='" + email + '\'' +
                '}';
    }

    // getters and setters
}

JSONB 示例

虽然 JSONB 是一种二进制格式,但在 Java 中,我们通常不会直接处理 JSONB 数据。相反,我们会使用类似于 Jackson 的库来序列化和反序列化 JSON 数据,并依赖于数据库(例如 PostgreSQL)处理 JSONB 数据存储。

示例:将 JSON 数据存储到 PostgreSQL JSONB 列

sql 复制代码
-- 创建表,包含 JSONB 列
CREATE TABLE example_jsonb (
    id SERIAL PRIMARY KEY,
    data JSONB
);

-- 插入 JSONB 数据
INSERT INTO example_jsonb (data) VALUES ('{"name": "Alice", "age": 30}');

Java 代码

java 复制代码
import com.fasterxml.jackson.databind.ObjectMapper;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;

public class JsonbExample {
    public static void main(String[] args) {
        ObjectMapper objectMapper = new ObjectMapper();
        String url = "jdbc:postgresql://localhost:5432/mydatabase";
        String user = "myuser";
        String password = "mypassword";

        try (Connection conn = DriverManager.getConnection(url, user, password)) {
            // 创建 Java 对象
            User userObj = new User(2, "Bob", "bob@example.com");
            String jsonString = objectMapper.writeValueAsString(userObj);

            // 插入 JSONB 数据到 PostgreSQL
            String insertSql = "INSERT INTO example_jsonb (data) VALUES (?::jsonb)";
            try (PreparedStatement pstmt = conn.prepareStatement(insertSql)) {
                pstmt.setString(1, jsonString);
                pstmt.executeUpdate();
            }

            // 查询 JSONB 数据
            String selectSql = "SELECT data FROM example_jsonb WHERE id = ?";
            try (PreparedStatement pstmt = conn.prepareStatement(selectSql)) {
                pstmt.setInt(1, 2);
                try (ResultSet rs = pstmt.executeQuery()) {
                    if (rs.next()) {
                        String data = rs.getString("data");
                        User retrievedUser = objectMapper.readValue(data, User.class);
                        System.out.println("Retrieved User: " + retrievedUser);
                    }
                }
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

总结

  • JSON 适合更灵活的数据存储和简单查询,适用于写操作频繁但读操作不频繁的场景。
  • JSONB 适合需要高效查询和索引的数据存储,适用于读操作频繁、需要高效查询和复杂操作的场景。

在 Java 中,可以使用 Jackson 等库来处理 JSON 数据,并通过数据库(如 PostgreSQL)来存储和查询 JSONB 数据。

相关推荐
熊小猿1 小时前
在 Spring Boot 项目中使用分页插件的两种常见方式
java·spring boot·后端
paopaokaka_luck1 小时前
基于SpringBoot+Vue的助农扶贫平台(AI问答、WebSocket实时聊天、快递物流API、协同过滤算法、Echarts图形化分析、分享链接到微博)
java·vue.js·spring boot·后端·websocket·spring
小蒜学长3 小时前
springboot酒店客房管理系统设计与实现(代码+数据库+LW)
java·数据库·spring boot·后端
橙子家3 小时前
Serilog 日志库简单实践(一):文件系统 Sinks(.net8)
后端
Yeats_Liao3 小时前
Go Web 编程快速入门 13 - 部署与运维:Docker容器化、Kubernetes编排与CI/CD
运维·前端·后端·golang
Yeats_Liao4 小时前
Go Web 编程快速入门 14 - 性能优化与最佳实践:Go应用性能分析、内存管理、并发编程最佳实践
前端·后端·性能优化·golang
七夜zippoe5 小时前
仓颉语言核心特性深度解析——现代编程范式的集大成者
开发语言·后端·鸿蒙·鸿蒙系统·仓颉
软件架构师-叶秋5 小时前
spring boot入门篇之开发环境搭建
java·spring boot·后端
QX_hao6 小时前
【Go】--接口(interface)
开发语言·后端·golang
superman超哥6 小时前
仓颉语言中正则表达式引擎的深度剖析与实践
开发语言·后端·仓颉