更新时间:2023-05-08 来源:黑马程序员 浏览量:

要保证数据库主键唯一性通常是通过数据库本身来实现的。一般情况下,我们使用数据库中的主键约束来保证主键的唯一性。在Java中,我们可以使用JDBC来操作数据库,通过使用预编译语句和设置参数来实现对数据库中的主键的添加、修改和查询。
以下是一个简单的示例,演示了如何使用JDBC来向数据库中添加一个带有自增长主键的记录,并保证该主键的唯一性:
import java.sql.*;
public class Main {
public static void main(String[] args) {
String url = "jdbc:mysql://localhost:3306/mydb";
String username = "root";
String password = "password";
String sql = "INSERT INTO users (username, password) VALUES (?, ?)";
try (Connection conn = DriverManager.getConnection(url, username, password);
PreparedStatement stmt = conn.prepareStatement(sql, Statement.RETURN_GENERATED_KEYS)) {
stmt.setString(1, "Alice");
stmt.setString(2, "mypassword");
int affectedRows = stmt.executeUpdate();
if (affectedRows == 0) {
throw new SQLException("Creating user failed, no rows affected.");
}
try (ResultSet generatedKeys = stmt.getGeneratedKeys()) {
if (generatedKeys.next()) {
int userId = generatedKeys.getInt(1);
System.out.println("Inserted user with ID: " + userId);
} else {
throw new SQLException("Creating user failed, no ID obtained.");
}
}
} catch (SQLException ex) {
System.err.println(ex.getMessage());
}
}
}在上面的示例中,我们使用了PreparedStatement来执行插入操作,并使用Statement.RETURN_GENERATED_KEYS参数来返回生成的主键。当插入操作成功后,我们可以使用ResultSet来获取主键的值。
需要注意的是,在执行插入操作时,我们并没有显式地设置主键的值。这是因为我们使用了自增长主键。在这种情况下,数据库会自动为我们分配一个唯一的主键值。
如果我们使用的是其他类型的主键,例如UUID或者字符串类型,那么你需要确保在插入操作时,主键的值是唯一的。你可以通过在数据库中创建一个唯一性索引来实现这一点。
【AI设计】北京143期毕业仅36天,全员拿下高薪offer!黑马AI设计连续6期100%高薪就业
2025-09-19【跨境电商运营】深圳跨境电商运营毕业22个工作日,就业率91%+,最高薪资达13500元
2025-09-19【AI运维】郑州运维1期就业班,毕业14个工作日,班级93%同学已拿到Offer, 一线均薪资 1W+
2025-09-19【AI鸿蒙开发】上海校区AI鸿蒙开发4期5期,距离毕业21天,就业率91%,平均薪资14046元
2025-09-19【AI大模型开发-Python】毕业33个工作日,就业率已达到94.55%,班均薪资20763元
2025-09-19【AI智能应用开发-Java】毕业当天offer率91%,薪资1W+占比54.2%,班级均薪12k+
2025-09-19