在MySQL数据库操作中,我们经常会使用Statement对象来执行SQL语句。Statement提供了三种方法:`execute(String sql)`、`executeUpdate(String sql)`和`executeQuery(String sql)`,它们各自有特定的用途和返回值,下面我们详细讲解这三者之间的区别。
1. `boolean execute(String sql)`
`execute`方法允许执行各种类型的SQL语句,包括查询(SELECT)、更新(INSERT、UPDATE、DELETE)以及数据定义语言(DDL,如CREATE TABLE、ALTER TABLE等)。如果执行的是查询语句,它将返回`true`,此时可以通过`getResultSet`方法获取结果集;如果执行的是更新语句或DDL语句,它将返回`false`,这时可以使用`getUpdateCount`方法获取受影响的行数。下面是一个示例:
```java
stm.execute("select * from stuinfo"); // 返回true,获取结果集
ResultSet rs = stm.getResultSet();
while(rs.next()){
System.out.println("姓名:"+rs.getString("stuName")+"\t年龄:"+rs.getString("stuScore"));
}
stm.execute("update stuinfo set stuScore=62 where stuname='张三'"); // 返回false,获取更新行数
int count = stm.getUpdateCount();
System.out.println(count + "条数据修改成功!");
```
2. `int executeUpdate(String sql)`
`executeUpdate`方法专门用于执行那些会改变数据库状态的SQL语句,例如INSERT、UPDATE、DELETE以及DDL语句。返回值是受影响的行数,对于DDL语句,返回值通常是0,因为它们通常不改变数据量。以下是一个例子:
```java
stm.executeUpdate("update stuinfo set stuScore=62 where stuname='张三'"); // 更新张三的成绩
int count = stm.getUpdateCount();
System.out.println(count + "条数据修改成功!");
```
3. `ResultSet executeQuery(String sql)`
`executeQuery`方法用于执行返回单个`ResultSet`对象的SQL语句,通常这些语句是SELECT查询。返回的结果集可以遍历以获取查询结果。如下所示:
```java
stm.executeQuery("select * from stuinfo"); // 获取结果集
ResultSet rs = stm.getResultSet();
while(rs.next()){
System.out.println("姓名:"+rs.getString("stuName")+"\t年龄:"+rs.getString("stuScore"));
}
```
总结一下,`execute`方法是一个通用方法,能处理多种类型的SQL语句,但使用起来比较复杂,因为它需要根据返回值判断SQL语句的类型。而`executeUpdate`和`executeQuery`则更具体,分别针对更新操作和查询操作,它们的返回值直接反映了操作的结果。在编写代码时,如果已知SQL语句的类型,使用`executeUpdate`和`executeQuery`会更清晰、更直观。