阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

JDBC更新

63次阅读
没有评论

共计 2412 个字符,预计需要花费 7 分钟才能阅读完成。

数据库操作总结起来就四个字:增删改查,行话叫 CRUD:Create,Retrieve,Update 和 Delete。

查就是查询,我们已经讲过了,就是使用 PreparedStatement 进行各种SELECT,然后处理结果集。现在我们来看看如何使用 JDBC 进行增删改。

插入

插入操作是 INSERT,即插入一条新记录。通过 JDBC 进行插入,本质上也是用PreparedStatement 执行一条 SQL 语句,不过最后执行的不是executeQuery(),而是executeUpdate()。示例代码如下:

try (Connection conn = DriverManager.getConnection(JDBC_URL, JDBC_USER, JDBC_PASSWORD)) {try (PreparedStatement ps = conn.prepareStatement("INSERT INTO students (id, grade, name, gender) VALUES (?,?,?,?)")) {ps.setObject(1, 999); // 注意:索引从 1 开始
        ps.setObject(2, 1); // grade
        ps.setObject(3, "Bob"); // name
        ps.setObject(4, "M"); // gender
        int n = ps.executeUpdate(); // 1
    }
}

设置参数与查询是一样的,有几个 ? 占位符就必须设置对应的参数。虽然 Statement 也可以执行插入操作,但我们仍然要严格遵循 绝不能手动拼 SQL 字符串 的原则,以避免安全漏洞。

当成功执行 executeUpdate() 后,返回值是int,表示插入的记录数量。此处总是1,因为只插入了一条记录。

插入并获取主键

如果数据库的表设置了自增主键,那么在执行 INSERT 语句时,并不需要指定主键,数据库会自动分配主键。对于使用自增主键的程序,有个额外的步骤,就是如何获取插入后的自增主键的值。

要获取自增主键,不能先插入,再查询。因为两条 SQL 执行期间可能有别的程序也插入了同一个表。获取自增主键的正确写法是在创建 PreparedStatement 的时候,指定一个 RETURN_GENERATED_KEYS 标志位,表示 JDBC 驱动必须返回插入的自增主键。示例代码如下:

try (Connection conn = DriverManager.getConnection(JDBC_URL, JDBC_USER, JDBC_PASSWORD)) {try (PreparedStatement ps = conn.prepareStatement("INSERT INTO students (grade, name, gender) VALUES (?,?,?)",
            Statement.RETURN_GENERATED_KEYS)) {ps.setObject(1, 1); // grade
        ps.setObject(2, "Bob"); // name
        ps.setObject(3, "M"); // gender
        int n = ps.executeUpdate(); // 1
        try (ResultSet rs = ps.getGeneratedKeys()) {if (rs.next()) {long id = rs.getLong(1); // 注意:索引从 1 开始
            }
        }
    }
}

观察上述代码,有两点注意事项:

一是调用 prepareStatement() 时,第二个参数必须传入常量Statement.RETURN_GENERATED_KEYS,否则 JDBC 驱动不会返回自增主键;

二是执行 executeUpdate() 方法后,必须调用 getGeneratedKeys() 获取一个 ResultSet 对象,这个对象包含了数据库自动生成的主键的值,读取该对象的每一行来获取自增主键的值。如果一次插入多条记录,那么这个 ResultSet 对象就会有多行返回值。如果插入时有多列自增,那么 ResultSet 对象的每一行都会对应多个自增值(自增列不一定必须是主键)。

更新

更新操作是 UPDATE 语句,它可以一次更新若干列的记录。更新操作和插入操作在 JDBC 代码的层面上实际上没有区别,除了 SQL 语句不同:

try (Connection conn = DriverManager.getConnection(JDBC_URL, JDBC_USER, JDBC_PASSWORD)) {try (PreparedStatement ps = conn.prepareStatement("UPDATE students SET name=? WHERE id=?")) {ps.setObject(1, "Bob"); // 注意:索引从 1 开始
        ps.setObject(2, 999);
        int n = ps.executeUpdate(); // 返回更新的行数
    }
}

executeUpdate()返回数据库实际更新的行数。返回结果可能是正数,也可能是 0(表示没有任何记录更新)。

删除

删除操作是 DELETE 语句,它可以一次删除若干行。和更新一样,除了 SQL 语句不同外,JDBC 代码都是相同的:

try (Connection conn = DriverManager.getConnection(JDBC_URL, JDBC_USER, JDBC_PASSWORD)) {try (PreparedStatement ps = conn.prepareStatement("DELETE FROM students WHERE id=?")) {ps.setObject(1, 999); // 注意:索引从 1 开始
        int n = ps.executeUpdate(); // 删除的行数
    }
}

练习

使用 JDBC 更新数据库。

下载练习

小结

使用 JDBC 执行 INSERTUPDATEDELETE都可视为更新操作;

更新操作使用 PreparedStatementexecuteUpdate()进行,返回受影响的行数。

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2024-08-05发表,共计2412字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中