当前位置: 首页 > article >正文

【Java】笔记:JDBC中Statement常用的几个执行函数

1.executeQuery(String sql): ResultSet

用于执行查询语句(SELECT),返回一个 ResultSet 对象,该对象包含了查询结果的数据。可以通过 ResultSet 提供的方法来获取查询结果。

//声明statement
Statement statement = connection.createStatement();
//发送查询语句
ResultSet resultSet = statement.executeQuery("SELECT id, name FROM employees");
//遍历查询结果
while (resultSet.next()) {
    int id = resultSet.getInt("id");
    String name = resultSet.getString("name");
    System.out.println("ID: " + id + ", Name: " + name);

2.executeUpdate(String sql): int

用于执行更新语句,如 INSERT(添加)、UPDATE(更新)、DELETE(删除) 等,返回一个表示影响的行数的整数。可以用来判断操作是否成功,若返回值大于等于0则说明执行成功,若为负数则说明执行失败。

Statement statement = connection.createStatement();
int rowCount = statement.executeUpdate("UPDATE employees SET salary = salary * 1.1 WHERE department = 'IT'");
System.out.println("Updated " + rowCount + " rows.");
// 判断是否执行成功
if (rowCount >= 0) {
    System.out.println("更新成功,影响了 " + rowCount + " 行。");
} else {
    System.out.println("更新失败。");
}

3.execute(String sql): boolean

用于执行任意 SQL 语句,返回一个表示是否有结果集的布尔值。如果有结果集,可以通过 getResultSet() 方法获取。

Statement statement = connection.createStatement();
boolean hasResultSet = statement.execute("DROP TABLE employees");
if (hasResultSet) {
    System.out.println("表删除成功!");
}

4.addBatch(String sql): void

用于将 SQL 语句添加到批处理中,以便一次性执行多个 SQL 语句。通常与 executeBatch() 一起使用。返回值是 void,表示成功添加到批处理中。

Statement statement = connection.createStatement();
statement.addBatch("INSERT INTO employees (name, salary) VALUES ('John Doe', 50000)");
statement.addBatch("INSERT INTO employees (name, salary) VALUES ('Jane Smith', 60000)");
statement.executeBatch()

5.setFetchSize(int rows): void

用于设置从数据库获取的行数,可以提高性能,尤其在处理大量数据时。返回值是 void。指定的行数可能不一定生效,具体取决于数据库驱动的实现。


http://www.kler.cn/news/234885.html

相关文章:

  • Linux中FIFO管道
  • 第六篇【传奇开心果系列】Vant of Vue 开发移动应用示例:深度解析响应式布局支持
  • acwing14期周赛---------安排时间(贪心+枚举)
  • STM32控制JQ8400语音播报模块
  • JavaScript 设计模式之外观模式
  • CSS盒子的概念
  • 《UE5_C++多人TPS完整教程》学习笔记8 ——《P9 访问 Steam(Acessing Steam)》
  • 2021年通信工程师初级 实务 真题
  • 刘谦春晚魔术的数学原理
  • 【开源】SpringBoot框架开发个人健康管理系统
  • 介绍 HTTPS 中间人攻击
  • 26.篮球练习
  • Android编程权威指南(第四版)- 第 4 章 UI状态的保存与恢复
  • 【WPF.NET开发】优化性能:其他建议
  • fast.ai 机器学习笔记(三)
  • 【开源】JAVA+Vue.js实现森林火灾预警系统
  • Rhino.Inside带材质将Revit模型bake到Rhino
  • 使用 FFmpeg 将视频转换为 GIF 动画的技巧
  • kafka教程
  • JavaWeb后端开发(第一期):Maven基础、Maven的安装配置、如何创建maven项目模块、maven的生命周期
  • 链表:反转链表
  • Flask 入门7:使用 Flask-Moment 本地化日期和时间
  • [ai笔记1] 借着“ai春晚”开个场
  • 第三百一十五回
  • [ai笔记3] ai春晚观后感-谈谈ai与艺术
  • Linux---网络套接字
  • Linux(Ubuntu) 环境搭建:Nginx
  • 【MySQL基础】:深入探索DQL数据库查询语言的精髓(上)
  • 创建你的第一个Vue项目(小白专享版本)
  • 《Django+React前后端分离项目开发实战:爱计划》 02 安装Python和Django