JDBC 学习笔记(五)—— Statement

Statement 是用来执行 SQL 语句的接口,它提供了三个方法来执行 SQL 语句:

boolean execute(String sql) throws SQLException;

int executeUpdate(String sql) throws SQLException;

ResultSet executeQuery(String sql) throws SQLException;

另外,在 Java8 中,还新增了 executeLargeUpdate() 方法,针对更新行数超过 Integer.MAX_VALUE 的情况。

default long executeLargeUpdate(String sql) throws SQLException {
    throw new UnsupportedOperationException("executeLargeUpdate not implemented");
}

1. execute()

execute() 方法,提供了一个通用的接口去执行 SQL 语句,它能够接受任何 SQL 语句,返回的布尔值是判断是否有 ResultSet 返回。

Statement 提供了一下两个接口去获得 execute() 真正的执行结果(分别针对 executeUpdate() 和 executeQuery() 的情况):

ResultSet getResultSet() throws SQLException;

int getUpdateCount() throws SQLException;

2. executeUpdate()

executeUpdate() 方法,是用来执行 DML 语句中的 INSERT, DELETE, UPDATE,返回受这个 DML 语句影响的行数。

但是,这个方法,在执行 SELECT 语句,或者是 DDL、DCL 语句也不会出错,并且能够正确执行,返回结果是0。

3. executeQuery()

executeQuery() 方法,是用来执行 DML 语句中的 SELECT,返回 ResultSet 结果集。

这个方法在执行非 SELECT 的 SQL 语句时,会抛出异常,执行的内容不会影响数据库。

java.sql.SQLException: query does not return ResultSet
	at org.sqlite.jdbc3.JDBC3Statement.executeQuery(JDBC3Statement.java:85)
	at com.gerrard.demo.StatementDemo.main(StatementDemo.java:20)

4. executeLargeUpdate()

executeLargeUpdate() 方法适用的范围很小,返回结果是 long 型,接受的 SQL 语句与 executeUpdate() 完全相同。

很多数据库厂商都没有开放对 executeLargeUpdate() 的支持。

猜你喜欢

转载自www.cnblogs.com/jing-an-feng-shao/p/9220707.html
今日推荐