15.6 JDBC数据库编程6——可滚动和可更新的ResultSet

目录

15.6  引言

15.6.1  可滚动的ResultSet

15.6.1  可更新的ResultSet


15.6  引言

可滚动的ResultSet是指在结果集对象上不但可以向前访问结果集中的记录,还可以向后访问结果集中记录。可更新的ResultSet是指不但可以访问结果集中的记录,还可以更新结果对象。

15.6.1  可滚动的ResultSet

        要使用可滚动的Result对象,必须使用Connection对象带参数的createStatement()方法创建的Statement,或使用带参数的PreopareStatement()方法创建PreparedStatement。在该对象上创建的结果集才是可滚动的,这两个方法的格式为:

  • public Statement createStatement(int resultSetType,int concurrency))
  • public PreparedStatement prepareStatement(String sql, int resultSetType,int concurrency);

        如果Statement对象或PreparedStatement对象用于查询,那么这两个参数决定executeQuery()方法返回的ResultSet是否是一个可滚动,可更新的ResultSet:

参数resultSetType的取值为ResultSet接口中定义的下面常量:

  • ResultSet.TYPE_SCROLL_SENSITIVE;
  • ResultSet.TYPE_SCROLL_INSENSITIVE;
  • ResultSet.TYPE_FORWORD_ONLY;

        前两个常量与与创建可滚动的ResultSet。如果使用TYPE_SCROLL_SENSITIVE常量,当数据库发生改变时,这些变化对结果集是敏感的,即数据库变化对结果集可见;如果使用TYPE_SCROLL_INSENSITIVE常量,当数据库发生改变时,这些变化对结果集是不敏感的,即这些变化对结果集不可见。使用TYPE_FORWORD_ONLY常量将创建一个不可滚动的结果集。

对可滚动的结果集,ResultSet接口提供了下面的移动游标的方法:

  • public boolean previous() throws SQLException:游标向前移动一行,如果存在合法的行返回true,否则返回false。
  • public boolean first() throws SQLException:移动游标指向第一行。
  • public boolean last() throws SQLException:移动游标指向最后一行。
  • public boolean absolute() throws SQLException:移动游标指向指定的行。
  • public boolean relative(int rows) throws SQLException:以当前行为基准相对游标的指针,rows为向后或向前的行数。rows若为正值是向前移动;若为负值是向后移动。
  • public boolean isFirst() throws SQLException:返回游标是否指向第一行。
  • public boolean isLast() throws SQLException:返回游标是否指向最后一行。

15.6.1  可更新的ResultSet

        在使用Connection的createStatement(int,int)创建Statement对象时,指定concurrency参数的值决定是否创建可更新的结果集,该参数也使用ResultSet接口中定义的常量,如下所示:

  • ResultSet.CONCUR_READ_ONLY
  • ResultSet.CONCUR_UPDATABLE

使用第一个常量创建只读的ResultSet对象,不能通过它更新表,使用第二个常量则创建可更新的结果集对象。

PreparedStatement pre=
conn.prepareStatement(sql, ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_UPDATABLE);
ResultSet rs=pre.executeQuery();

 得到可更新的ResultSet对象后,就可以调用适当的updateXxx()方法更新当前行指定列的值。对于每种数据类型,ResultSet都定义了相应的updateXxx()方法

  • public void updateInt(int columnIndex,int x):用指定的整数x的值更新当前行指定列的值,其中columnIndex为列的序号
  • public void updateInt(int columnName,int x):用指定的整数x的值更新当前行指定列的值,其中columnName为列名
  • public void updateString(int columnIndex,int x):用指定的字符串x的值更新当前行指定列的值,其中columnIndex为列的序号
  • public void updateString(int columnIndex,int x):用指定的字符串x的值更新当前行指定列的值,其中columnName为列名

每个updateXxx()方法都有两个重载的版本,一个是第一个参数为int类型的,用来指定更新的列号;另一个是第一个参数为为String类型的,用来指定更新的列名。第二个参数的类型与要更新列的类型一致。有关其他方法请参考Java API文档。

下面是通过可更新的ResultSet对象更新表的方法

  • public void updateRow() throws SQLException:执行方法后,将用当前行的新内容更新结果集,同时更新数据库
  • public void cancelRowUpdate() throws SQLException:取消对结果集当前行的更新。
  • public void moveToInsertRow() throws SQLException:将游标移到插入行。它实际上是一个新行的缓冲区。当游标处于插入行时,调用updateXxx()方法用相应的数据修改每列的值。
  • public void insertRow() thorws SQLException:将当前新行插入到数据库中
  • public void deleteRow() throws SQLException:将结果集中删除当前行,同时从数据库中将该行删除。

        当使用updateXxx()方法更新当前行的所有列之后,调用updateRow()方法把更新写入表中。调用deleteRow()方法从一个表或ResultSet中删除一行数据。
        要插入一行数据首先应该使用moveToInsertRow()方法将游标移动到插入行,当游标处于插入行时,调用updateXxx()方法用相应的数据修改每列的值,最后调用insertRow()方法将新行插入到数据库中。在调用insertRow()方法之前,该行所有的列都必须给定一个值。调用insertRow()方法之后,游标仍位于插入行。这时,可以插入另外一行数据,或移到刚才ResultSet记住的位置(当前行位置)。通过调用moveToCurrentRow()方法返回到当前行。可以在调用insertRow()方法之前调用moveToCurrentRow()方法取消插入。

        下面代码说明了如何在products表中修改一件商品的信息:

import java.sql.*;public class JDBCselect {public static void main(String[] args) throws ClassNotFoundException {Class.forName("com.mysql.cj.jdbc.Driver");String url = "jdbc:mysql://127.0.0.1:3306/webstore?useSSL=true";String name = "root";String password = "root";String sql = "select * from products";try (Connection conn = DriverManager.getConnection(url, name, password);Statement stmt = conn.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_UPDATABLE)        ) {ResultSet rst = stmt.executeQuery(sql);
//            while (rst.next()) {
//                System.out.println(rst.getInt(1)
//                        + "\t"
//                        + rst.getString(2)
//                        + "\t"
//                        + rst.getString(3)
//                        + "\t"
//                        + rst.getDouble(4)
//                        + "\t"
//                        + rst.getInt(5));
//            }rst.moveToInsertRow();rst.updateInt(1,109);rst.updateString(2,"苹果");rst.updateString(3,"新西方");rst.updateDouble(4,7500);rst.updateInt(5,21);rst.insertRow();rst.moveToCurrentRow();} catch (SQLException e) {e.printStackTrace();}}
}

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/456103.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

关于移动硬盘复制文件0x80071AC3错误解决方法

一、问题详情 新入手的西部数据移动硬盘在复制文件到手机是没有问题的,但是在电脑复制文件的时候,电脑弹出0x80071AC3错误,没办法复制文件,也没办法新建文件夹。 二、原因 因为卷有问题,请运行chkdsk并重试。 三、解…

使用Vue.js构建响应式Web应用

💖 博客主页:瑕疵的CSDN主页 💻 Gitee主页:瑕疵的gitee主页 🚀 文章专栏:《热点资讯》 使用Vue.js构建响应式Web应用 1 引言 2 Vue.js简介 3 安装Vue CLI 4 创建Vue项目 5 设计应用结构 6 创建组件 7 使用…

SLAM|1. 相机投影及相机畸变

一个能思考的人,才真是一个力量无边的人。——巴尔扎克 本章主要内容: 1.针孔相机模型 2.相机成像的几个坐标系图像 3.畸变及相机标定 本节主要介绍在照相机拍摄过程中,现实物体如何跟照片上的像素关联起来,具体涉及相机成像的物…

LabVIEW换流变换器智能巡检系统

基于LabVIEW的换流变换器智能巡检系统通过自动化检测和数据分析,提高换流变换器的运行效率和可靠性,降低人工维护成本。 项目背景: 换流变压器作为电力系统的重要组成部分,其性能的可靠性直接影响到整个电网的稳定运行。然而&…

Spring Boot:植物健康的智能守护者

2相关技术 2.1 MYSQL数据库 MySQL是一个真正的多用户、多线程SQL数据库服务器。 是基于SQL的客户/服务器模式的关系数据库管理系统,它的有点有有功能强大、使用简单、管理方便、安全可靠性高、运行速度快、多线程、跨平台性、完全网络化、稳定性等,非常…

Python基于amazon/chronos-t5-base的预训练模型离线对时间系列数据的未来进行预测

Python基于预训练模型对时间系列数据的未来进行预测 导入库 %matplotlib inline import matplotlib.pyplot as plt import numpy as np import pandas as pd import torch from chronos import ChronosPipeline from tqdm.auto import tqdm from autogluon.timeseries import…

【Java】使用iText依赖生成PDF文件

文章目录 使用iText实现PDF文件生成1. 需求2 . 添加依赖3. 核心4. 实战案例:生成录用通知书4.1 整体架构4.2 初始化PDF文档4.3 配置中文字体4.4 添加背景图片4.5 添加文本内容4.6 处理文档生成 5. 关键技巧与注意事项5.1 字体处理5.2 图片处理5.3 布局控制5.4 异常处…

探索人工智能在自然语言处理中的应用

探索人工智能在自然语言处理中的应用 前言1. 机器翻译2. 情感分析3. 智能客服4. 文本生成未来展望 结语 前言 在信息爆炸的时代,自然语言处理(NLP)作为人工智能(AI)的一个重要分支,正以前所未有的速度改变着…

LabVIEW提高开发效率技巧----节省内存

在LabVIEW开发过程中,内存管理是保障程序稳定性和性能的关键。本文将详细介绍如何通过队列处理来节省内存,尤其是如何通过解耦释放不再需要的数据,防止内存泄漏。通过多个实际例子,从不同角度探讨队列处理在大数据量或长时间运行的…

苹果瑕疵数据集苹果质量数据集YOLO格式VOC格式 深度学习 目标检测 数据集

一、数据集概述 数据集名称:2类苹果图像数据集 数据集包含两类样本:正常苹果和有瑕疵的苹果。正常苹果样本代表完好的苹果,而有瑕疵的苹果样本代表苹果表面可能存在的损伤、瑕疵或病害。每个样本都经过详细标记和描述,以便训练模…

大语言模型数据类型与环境配置

文章目录 前言一、环境安装二、大语言模型数据类型1、基本文本指令数据类型2、数学指令数据类型3、几何图形指令数据类型4、多模态指令数据类型5、翻译指令数据类型 三、vscode配置 前言 简单给出环境安装与数据类型及vscode运行配置,其中vscode运行配置是便于我们…

专业135+总分400+西安交通大学815869(原909)信号与系统考研经验电子信息与通信工程,真题,大纲,参考书

经过将近一年的考研复习,终于梦圆西安交大,今年专业课815(和专硕869(原909)差不多)信号与系统135,总分400,回想这一年的复习还有很多经验和大家分享,希望可以对大家复习有所帮助,少走…

3.cpp基本数据类型

cpp基本数据类型 1.cpp基本数据类型 1.cpp基本数据类型 C基本数据类型和C语言的基本数据类型差不多 注意bool类型&#xff1a;存储真值 true 或假值 false&#xff0c;C语言编译器C99以上支持。 C语言的bool类型&#xff1a;要添加 #include <stdbool.h>头文件 #includ…

数据库相关知识点

1. 数据库分片与分区 分片&#xff08;Sharding&#xff09;&#xff1a;这是一种将数据水平分割的技术&#xff0c;每个分片包含数据的一个子集。分片通常用于提高数据库的扩展性和性能&#xff0c;特别是在处理大量数据时。通过将数据分布在多个分片上&#xff0c;可以并行处…

ruoyi域名跳转缓存冲突问题(解决办法修改:session名修改session的JSESSIONID名称)

【版权所有&#xff0c;文章允许转载&#xff0c;但须以链接方式注明源地址&#xff0c;否则追究法律责任】【创作不易&#xff0c;点个赞就是对我最大的支持】 前言 仅作为学习笔记&#xff0c;供大家参考 总结的不错的话&#xff0c;记得点赞收藏关注哦&#xff01; 目录 前…

Maven基础知识

一、Maven的概述 maven 是什么&#xff1f; 是一个项目管理工具&#xff0c;它包含了一个项目对象模型&#xff0c;一组标准集合&#xff0c;一个项目的生命周期&#xff0c;一个依赖管理系统&#xff0c;和用来运行定义在生命周期阶段和插件目标的逻辑。 二、Maven的依赖管理…

【331】基于Springboot的“有光”摄影分享网站系统

“有光”摄影分享网站设计与实现 摘 要 自互联网的发展至今&#xff0c;其基础理论与技术都已完善&#xff0c;并积极参与了整个社会各个领域。它容许信息根据媒体传播&#xff0c;并和信息可视化工具一起为大家提供优质的服务。对于信息多头管理、差错率高、信息安全系数差、…

Redis 命令集 (超级详细)

目录 Redis 常用命令集 string类型 hash类型 list类型 set类型 zset类型 bitmap 类型 geo 类型 GEOADD (添加地理位置的坐标) GEOPOS (获取地理位置的坐标) GEODIST (计算两个位置之间的距离) GEOHASH (返回一个或多个位置对象的 geohash 值) GEORADIUS (根据用户…

本地docker部署中间件和应用

Docker Desktop搭建 安装完成之后使用docker下载镜像&#xff0c;报以下错误&#xff1a; 解决办法&#xff1a; Docker Engine配置能访问的镜像地址&#xff1a; {"builder": {"gc": {"defaultKeepStorage": "20GB","enabled…

Vue实现手风琴功能组件 vue 实现折叠面板功能

Vue实现手风琴功能组件 vue 实现折叠面板功能,前端不使用第三方组件实现手风琴折叠面板功能 效果图: dom<div class="foldSection"><divv-for="(item, index) in ListData":key="item.id"class="accordion"><div …