保存两个相关实体,其中主键由序列生成。
创始人
2024-11-22 14:00:16
0

在Oracle数据库中,可以使用序列(Sequence)来生成唯一的主键。下面是一个示例代码,展示了如何保存两个相关实体,并使用序列生成主键:

  1. 创建序列:
CREATE SEQUENCE entity_sequence
    START WITH 1
    INCREMENT BY 1
    NOCACHE
    NOCYCLE;
  1. 创建实体表:
CREATE TABLE entity1 (
    id NUMBER,
    name VARCHAR2(50),
    CONSTRAINT entity1_pk PRIMARY KEY (id)
);

CREATE TABLE entity2 (
    id NUMBER,
    entity1_id NUMBER,
    name VARCHAR2(50),
    CONSTRAINT entity2_pk PRIMARY KEY (id),
    CONSTRAINT entity2_fk FOREIGN KEY (entity1_id) REFERENCES entity1(id)
);
  1. Java代码示例:
import java.sql.*;

public class Main {
    public static void main(String[] args) {
        // 数据库连接信息
        String url = "jdbc:oracle:thin:@localhost:1521:xe";
        String username = "your_username";
        String password = "your_password";
        
        // 实体信息
        String entity1Name = "Entity1";
        String entity2Name = "Entity2";
        
        // 建立数据库连接
        try (Connection conn = DriverManager.getConnection(url, username, password)) {
            // 开启事务
            conn.setAutoCommit(false);
            
            // 保存实体1
            int entity1Id = saveEntity(conn, entity1Name);
            
            // 保存实体2
            saveEntity(conn, entity2Name, entity1Id);
            
            // 提交事务
            conn.commit();
            
            System.out.println("保存成功!");
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }
  
    // 保存实体1
    private static int saveEntity(Connection conn, String name) throws SQLException {
        String sql = "INSERT INTO entity1 (id, name) VALUES (entity_sequence.nextval, ?)";
        try (PreparedStatement stmt = conn.prepareStatement(sql, Statement.RETURN_GENERATED_KEYS)) {
            stmt.setString(1, name);
            stmt.executeUpdate();
            
            // 获取生成的主键值
            try (ResultSet rs = stmt.getGeneratedKeys()) {
                if (rs.next()) {
                    return rs.getInt(1);
                } else {
                    throw new SQLException("无法获取生成的主键值!");
                }
            }
        }
    }
  
    // 保存实体2
    private static void saveEntity(Connection conn, String name, int entity1Id) throws SQLException {
        String sql = "INSERT INTO entity2 (id, entity1_id, name) VALUES (entity_sequence.nextval, ?, ?)";
        try (PreparedStatement stmt = conn.prepareStatement(sql)) {
            stmt.setInt(1, entity1Id);
            stmt.setString(2, name);
            stmt.executeUpdate();
        }
    }
}

请注意替换代码中的数据库连接信息和实体信息,以适应您的环境。

相关内容

热门资讯

第8分钟了解!余干辅助软件哪个... 第8分钟了解!余干辅助软件哪个好!原来是真的有辅助插件(有挂总结)-哔哩哔哩1、上手简单,内置详细流...
第9分钟了解!牵手跑辅助!一贯... 第9分钟了解!牵手跑辅助!一贯真的是有辅助神器(有挂技巧)-哔哩哔哩1、牵手跑辅助辅助器安装包、牵手...
两分钟了解!浙江游戏温州熟客辅... 两分钟了解!浙江游戏温州熟客辅助!切实一直都是有辅助插件(果真有挂)-哔哩哔哩1、每一步都需要思考,...
第三分钟了解!海螺众娱脚本!真... 第三分钟了解!海螺众娱脚本!真是是真的有辅助教程(有挂解密)-哔哩哔哩1)海螺众娱脚本免费钻石:进一...
十分钟了解!决战血流辅助!一贯... 十分钟了解!决战血流辅助!一贯一直都是有辅助技巧(有挂详情)-哔哩哔哩运决战血流辅助辅助工具,进入游...
四分钟了解!开心泉州作必弊!果... 四分钟了解!开心泉州作必弊!果然存在有辅助技巧(有挂细节)-哔哩哔哩1、开心泉州作必弊透视辅助软件激...
三分钟了解!情怀麻烦将关春天辅... 三分钟了解!情怀麻烦将关春天辅助!其实一直总是有辅助神器(有挂教学)-哔哩哔哩1、完成情怀麻烦将关春...
8分钟了解!福建十三水软件开发... 8分钟了解!福建十三水软件开发!一直有辅助工具(有挂秘诀)-哔哩哔哩该软件可以轻松地帮助玩家将福建十...
九分钟了解!手游奇迹陕西辅助工... 九分钟了解!手游奇迹陕西辅助工具!果然一直都是有辅助方法(真实有挂)-哔哩哔哩该软件可以轻松地帮助玩...
第5分钟了解!微信海豚大厅辅助... 第5分钟了解!微信海豚大厅辅助!总是一直总是有辅助软件(证实有挂)-哔哩哔哩该软件可以轻松地帮助玩家...