JDBC 使用 Statement 作为 SQL 语句的执行器。

Statement 通过 Connection.createStatement() 方法创建,一共支持以下6种方式执行 SQL 语句:

  • execute()
  • executeUpdate()
  • executeQuery()
  • executeLargeUpdate()
  • executeBatch()
  • executeLargeBatch()

1. execute()

boolean execute(String sql) throws SQLException;

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

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

ResultSet getResultSet() throws SQLException;

int getUpdateCount() throws SQLException;

2. executeUpdate()

int executeUpdate(String sql) throws SQLException;

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

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

3. executeQuery()

ResultSet executeQuery(String sql) throws SQLException;

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()

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

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

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

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

5. executeBatch()

Statement 还提供了 executeBatch() 方法来支持 SQL 语句的批处理:

int[] executeBatch() throws SQLException;

使用 executeBatch() 方法,首先需要通过 addBatch() 方法注入 SQL 语句:

void addBatch( String sql ) throws SQLException;

这里需要注意的是,executeBatch() 不支持 SELECT 语句。

6. executeLargeBatch()

与 executeUpdate() 类似,Java8 提供了 executeLargeBatch() 方法增强批量更新。

批处理的时候,任意一条 SQL 语句返回值大于 Integer.MAX_VALUE,就要使用这个方法:

default long[] executeLargeBatch() throws SQLException {
throw new UnsupportedOperationException("executeLargeBatch not implemented");
}

7. Demo

最后贴一个自己写的例子:

package com.gerrard.demo;

import com.gerrard.util.Connector;
import com.gerrard.util.DriverLoader; import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement; public final class StatementDemo { public static void main(String[] args) { String querySql = "SELECT * from STUDENT";
String updateSql1 = "UPDATE STUDENT SET STUDENT_PASSWORD = '123456' WHERE STUDENT_PASSWORD = '123456'";
String updateSql2 = "UPDATE STUDENT SET STUDENT_PASSWORD = '223456' WHERE STUDENT_PASSWORD = '223456'"; DriverLoader.loadSqliteDriver();
try (Connection conn = Connector.getSqlConnection();
Statement stmt = conn.createStatement()) { // execute
boolean hasResult = stmt.execute(updateSql1);
if (hasResult) {
System.out.println("Execute query success");
} else {
System.out.println("Execute update success, affect" + stmt.getUpdateCount() + " rows");
} // executeUpdate
int rowCount1 = stmt.executeUpdate(updateSql1);
System.out.println("Affected " + rowCount1 + " rows"); // executeQuery
try (ResultSet rs = stmt.executeQuery(querySql)) {
int counter = 0;
while (rs.next()) {
counter++;
}
System.out.println(counter + " students in all");
} // executeBatch
stmt.addBatch(updateSql1);
stmt.addBatch(updateSql2);
stmt.addBatch(updateSql1);
int[] results = stmt.executeBatch();
for (int result : results) {
System.out.println("Affected " + result + " rows");
} // executeLargeUpdate
stmt.executeLargeUpdate(updateSql1); } catch (SQLException e) {
e.printStackTrace();
}
}
}

执行结果:

JDBC 学习笔记(五)—— Statement的更多相关文章

  1. JDBC学习笔记(2)——Statement和ResultSet

    Statement执行更新操作 Statement:Statement 是 Java 执行数据库操作的一个重要方法,用于在已经建立数据库连接的基础上,向数据库发送要执行的SQL语句.Statement ...

  2. 【转】JDBC学习笔记(2)——Statement和ResultSet

    转自:http://www.cnblogs.com/ysw-go/ Statement执行更新操作 Statement:Statement 是 Java 执行数据库操作的一个重要方法,用于在已经建立数 ...

  3. JDBC 学习笔记(十一)—— JDBC 的事务支持

    1. 事务 在关系型数据库中,有一个很重要的概念,叫做事务(Transaction).它具有 ACID 四个特性: A(Atomicity):原子性,一个事务是一个不可分割的工作单位,事务中包括的诸操 ...

  4. JDBC 学习笔记(十)—— 使用 JDBC 搭建一个简易的 ORM 框架

    1. 数据映射 当我们获取到 ResultSet 之后,显然这个不是我们想要的数据结构. 数据库中的每一个表,在 Java 代码中,一定会有一个类与之对应,例如: package com.gerrar ...

  5. JDBC 学习笔记(六)—— PreparedStatement

    1. 引入 PreparedStatement PreparedStatement 通过 Connection.createPreparedStatement(String sql) 方法创建,主要用 ...

  6. JDBC学习笔记二

    JDBC学习笔记二 4.execute()方法执行SQL语句 execute几乎可以执行任何SQL语句,当execute执行过SQL语句之后会返回一个布尔类型的值,代表是否返回了ResultSet对象 ...

  7. JDBC学习笔记一

    JDBC学习笔记一 JDBC全称 Java Database Connectivity,即数据库连接,它是一种可以执行SQL语句的Java API. ODBC全称 Open Database Conn ...

  8. C#可扩展编程之MEF学习笔记(五):MEF高级进阶

    好久没有写博客了,今天抽空继续写MEF系列的文章.有园友提出这种系列的文章要做个目录,看起来方便,所以就抽空做了一个,放到每篇文章的最后. 前面四篇讲了MEF的基础知识,学完了前四篇,MEF中比较常用 ...

  9. (转)Qt Model/View 学习笔记 (五)——View 类

    Qt Model/View 学习笔记 (五) View 类 概念 在model/view架构中,view从model中获得数据项然后显示给用户.数据显示的方式不必与model提供的表示方式相同,可以与 ...

  10. java之jvm学习笔记五(实践写自己的类装载器)

    java之jvm学习笔记五(实践写自己的类装载器) 课程源码:http://download.csdn.net/detail/yfqnihao/4866501 前面第三和第四节我们一直在强调一句话,类 ...

随机推荐

  1. JavaScript_7_运算符

    1. 算术运算符 2. 赋值运算符 3. 用于字符串的+运算 如果把字符串与数字相加,结果将成为字符串 <!DOCTYPE html> <html> <head> ...

  2. GetOpenFileName 选择文件夹的解决方法

    某些环境下(如WIN PE)windows自带的选择文件夹api不能使用或者体验不佳.现在利用GetOpenFileName的回掉参数实现了选择文件夹选择功能. #include <Window ...

  3. UVA 1599, POJ 3092 Ideal Path 理想路径 (逆向BFS跑层次图)

    大体思路是从终点反向做一次BFS得到一个层次图,然后从起点开始依次向更小的层跑,跑的时候选则字典序最小的,由于可能有多个满足条件的点,所以要把这层满足条件的点保存起来,在跑下一层.跑完一层就会得到这层 ...

  4. Android(java)学习笔记129:对ListView等列表组件中数据进行增、删、改操作

    1. ListView介绍 解决大量的相似的数据显示问题 采用了MVC模式: M: model (数据模型) V:  view  (显示的视图) C: controller 控制器 入门案例: aci ...

  5. C++链表简单的应用

    学生管理系统,输入学生的姓名和学号,然后再输出: #define _CRT_SECURE_NO_WARNINGS #include<stdio.h> #include <stdlib ...

  6. 实验十三 团队作业9:Beta冲刺与团队项目验收

    实验十三 团队作业9:Beta冲刺与团队项目验收 实验时间 2019-6-20(21) Deadline: [6.20-6.26]之间任选连续3天的23:00,以团队随笔博文提交时间为准. 评分标准: ...

  7. 一步一步构建iOS持续集成:Jenkins+GitLab+蒲公英+FTP

    什么是持续集成 持续集成是一种软件开发实践,即团队开发成员经常集成它们的工作,通过每个成员每天至少集成一次,也就意味着每天可能会发生多次集成.每次集成都通过自动化的构建(包括编译,发布,自动化测试)来 ...

  8. Intel Code Challenge Elimination Round (Div.1 + Div.2, combined)

    A. Broken Clock time limit per test 1 second memory limit per test 256 megabytes input standard inpu ...

  9. HashMap与ArrayMap(和SparseArray)的比较与选择

    HashMap与ArrayMap(和SparseArray)的比较与选择 2017年12月26日 06:04:38 阅读数:61 标签: androidjavahashmaparraymap数据结构 ...

  10. 一个4年工作经验的java程序员的困惑,怎样才能能为一个架构师,请教大神

    一个4年工作经验的java程序员的困惑,怎样才能能为一个架构师 LZ本人想往架构师发展, 业余时间也会看一些书籍, 但是感觉没有头绪, 有些书看了,也没有地方实践 我做了4年的java开发, 在一个公 ...