给有外键的数据库表格添加数据
前言: 在项目中,数据库表中在设计时肯定会有外键关联的,给有外键的表格测试添加数据,首先得把屏蔽掉外键。这里就是我在做项目时将生成的随机数据添加进数据库中,就遇见了这个问题,百度了很多资料也没找到解决方案,在灵光一闪之间,就想到一个方法这里我的项目是使用spring boot框架来构建的,但是我解决这个问题思路是回到数据库上面方案一:set foreign_key_checks = 0...
·
前言:
在项目中,数据库表中在设计时肯定会有外键关联的,给有外键的表格测试添加数据,首先得把屏蔽掉外键。这里就是我在做项目时将生成的随机数据添加进数据库中,就遇见了这个问题,百度了很多资料也没找到解决方案,在灵光一闪之间,就想到一个方法
这里我的项目是使用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条内容
所有评论(0)