给有外键的数据库表格添加数据

前言:
  在项目中,数据库表中在设计时肯定会有外键关联的,给有外键的表格测试添加数据,首先得把屏蔽掉外键。这里就是我在做项目时将生成的随机数据添加进数据库中,就遇见了这个问题,百度了很多资料也没找到解决方案,在灵光一闪之间,就想到一个方法

这里我的项目是使用spring boot框架来构建的,但是我解决这个问题思路是回到数据库上面

方案一:
set foreign_key_checks = 0

将外键检查值设置为0,设置完成后就可以向数据库中的任何表格添加数据,但是添加完成后需要将外键检查值改回去

"set foreign_key_checks = 1"

这个方案适用于次数较少的添加数据,如果次数多了,每次改起来就很烦躁,我在使用时就是因为需求变动很多次,然后该数据库,加数据,所以就想出了另外的方法

方案二:

基于方案一的方法,通过java代码的形式来更改外键值,封装好对应的方法,在添加数据前去调用一次改值为0的方法,完成后去调用改值为1的方法
使用数据库的jdbc思路,首先连接数据库,当然每次使用完记得关闭连接,然后PreparedStatement 去执行sql语句

private static String driver = "com.mysql.cj.jdbc.Driver";
    private static String url = "jdbc:mysql://127.0.0.1:3306/crmweb?serverTimezone=Asia/Shanghai";
    private static String username = "root";
    private static String password = "root";
    private static Connection conn = null;
    private static PreparedStatement pstmt = null;

    /**
     * 连接数据库
     * @return
     */
    private static Connection getConn() {
        try {
            Class.forName(driver);
            conn = DriverManager.getConnection(url, username, password);
        } catch (ClassNotFoundException | SQLException e) {
            e.printStackTrace();
        }
        return conn;
    }

    /**
     * 设置外键值为0
     */
    public static void setKey0() {
        Connection conn = getConn();
        String sql = "set foreign_key_checks = 0";
        try {
            pstmt = conn.prepareStatement(sql);
            pstmt.execute();
        } catch (SQLException e) {
            e.printStackTrace();
        } finally {
            close(conn, pstmt);
        }
    }

    /**
     * 设置外键值为1
     */
    public static void setKey1() {
        Connection conn = getConn();
        String sql = "set foreign_key_checks = 1";
        try {
            pstmt = conn.prepareStatement(sql);
            pstmt.execute();
        } catch (SQLException e) {
            e.printStackTrace();
        } finally {
            close(conn, pstmt);
        }
    }

    /**
     * 关闭数据库
     * @param conn
     * @param pstmt
     */
    private static void close(Connection conn, PreparedStatement pstmt) {
        if (pstmt != null) {
            try {
                pstmt.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
        if (conn != null) {
            try {
                conn.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
    }
  • 2
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

華小灼

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值