JavaEE JDBC 可滚动和可更新的结果集ResultSet
可滚动和可更新的结果集ResultSet
@author ixenos
需求背景
1.对于一个只需要分析数据的程序来说,普通的ResultSet已够用
2.但如果ResultSet用于显示一张表或查询结果的可视化数据显示,
1)会希望用户在结果集上前后移动的需求,
2)而且一旦展示了结果集的内容,用户会希望修改这些内容,这有两种方式:
(1)一般通过UPDATE语句修改(更高效)
(2)通过SELECT得到ResultSet,再遍历修改(意味着可以细化修改操作!)
3.需求总结:细化修改操作,且让用户能任意修改数据的交互程序,需要可滚动和可更新的结果集
4.注意:不是所有的数据库驱动程序都支持可滚动和可更新的结果集
可滚动的结果集
1.默认的结果集不可滚动
2.通过在Statement创建时填入ResultSet的相关参数(type,concurrency)开启功能
Statement stmt = conn.createStatement(type, concurrency);
PreparedStatement preStmt = conn.prepareStatement(command , type , concurrency);
3.ResultSet类的type值
TYPE_FORWARD_ONLY 结果集不能滚动(默认值)
TYPE_SCROLL_INSENSITIVE 结果集可以滚动,但对数据库变化不敏感
TYPE_SCROLL_SENSITIVE 结果集可以滚动,对数据库变化敏感
4.ResultSet类的concurrency值
CONCUR_READ_ONLY 结果集不能用于更新数据库(默认值)
CONCUR_UPDATABLE 结果集可以用于更新数据库
5.示例
1)只想滚动遍历结果集,而不想编辑数据
Statement stmt = conn.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_READ_ONLY); //现在调用执行得到的结果集就是可滚动的
ResultSet rs = stmt.executeQuery(query);
可滚动的结果集有一个游标,用以指示当前位置
2)结果集的滚动API
(1)将游标向后移动:rs.previous() (越界返回boolean值)
(2)相对位置:将游标向前或向后移动n行:rs.relative(n) (n为正数向前移动,n为负数向后移动,n为0不移动,越界返回boolean值)
(3)绝对位置:将游标移动到指定行:rs.absolute(n)
(4)返回行号:int currentRow = rs.getRow() (第一行行号是1,越界返回boolean值)
(5)其他位置:first、last、beforeFirst、afterLast
(6)判断:isFirst、isLast、isBeforeFirst、isAfterLast
可更新的结果集
1.获得可更新的结果集
Statement stmt = conn.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_UPDATABLE);
2.并不是设置参数之后所有的查询都会返回可更新的结果集!
(1)如果查询涉及多个表的连接,那么它所产生的结果集是不可更新的;
(2)如果查询只涉及一个表,或者是使用主键连接多个表的,那么它将产生可更新的结果集;
(3)可调用ResultSet的getConcurrency方法来确定可否更新;
3.API(CRUD操作)
1)更新操作
(1)所有对应于SQL类型的数据类型都有updateXXX方法,与getXXX方法类似用法:必须指定列的名称或序号;
()同样,这里序号指的是该列在ResultSet中的序号
(2)updateXXX改变的只是结果集中对应行的值,而非数据库中的值,当更新完行中的字段后,必须要调用updateRow方法提交到数据库中,否则所有更新操作将被丢弃
2)新建操作
(1)插入行:使用moveToInsertRow将游标移动到特定的位置
(2)创建行:调用updateXXX在插入行的位置上创建一个新的行
(3)回原行:调用moveToCurrentRow将游标移回到调用moveToInsetRow方法之前的位置
//插入行的游标位置是特定的,无需指定
rs.moveToInsertRow(); //在插入行插入数据
rs.updateString("Title", title);
rs.updateString("ISBN", isbn);
rs.updateString("Publisher_Id", pubid); //提交创建
rs.insertRow(); //游标回到原来的行
rs.moveToCurrentRow();
注意:你无法控制在结果集或数据库中添加新数据的位置;对于在插入行中没有指定值的列,将被设为NULL值,但如果有NOT NULL约束,将抛出异常且这一行是无法插入的
3)删除操作
//删除当前游标所指的行
rs.deleteRow();
deleteRow会立即将该行从结果集和数据库中删除
4)总结
ResultSet接口中的updateRow、insertRow和deleteRow方法 的执行效果等同于SQL命令中的UPDATE、INSERT和DELETE
4.应用场景示例:
(1)想提高某些图书的价格,但在执行UPDATE语句时又没有一个简单而同一个提价标准,这时需要遍历来修改,所以就用到了可滚动可更新的结果集,这时就比UPDATE灵活
String query = "SELECT * FROM Books";
ResultSet rs = stmt.executeQUERY(query); while(rs.next()){
//迭代结果集时,我们就可以根据业务条件来细化修改
if(...){
double increase = 。。。
double price = rs.getDouble("Price");
//更改结果集中当前行的字段值
rs.updateDouble("Price", price + increase);
//将更改提交到数据库,很关键不能漏
rs.updateRow();
}
}
优缺点
优点:细化修改操作,且让用户能任意修改数据的交互程序
缺点:1.在与用户的整个交互过程中,必须始终与数据库保持连接;
后果:当用户长时间离开时,数据库连接长时间被占用,而这属于稀缺资源;
解决:使用行集RowSet,RowSet继承了ResultSet接口,却无需始终保持与数据库的连接~
2.结果集不便于移动,因为数据结构复杂,且依赖于连接
解决:使用行集RowSet,RowSet适用于将查询结果移动到复杂应用的其他层,或者其他设备当中
JavaEE JDBC 可滚动和可更新的结果集ResultSet的更多相关文章
- java数据库编程——读写LOB、可滚动和可更新的结果集、元数据
java 数据库编程 1. 读写LOB 除了数字.字符串和日期之外,许多数据库还可以存储大对象,例如图片或其它数据.在SQL中,二进制大对象称为BLOB,字符型大对象称为CLOB. 要读取LOB,需要 ...
- JavaEE JDBC ResultSet内外移动
ResultSet内外移动 @author ixenos 内外移动指位置光标的移动 内移动就是一个ResultSet得到后的那个光标! 外移动就是多个ResultSet的迭代 内移动 一般的数据库都不 ...
- JDBC获取sql server存储过程查询结果集(没有出参)
对于一些较为复杂的统计条件查询,可以通过存储过程来实现,既可以提高效率,减少网络流量,也可以避免sql语句耦合在代码中.但是存储过程返回的结果集如何获取(类似表数据),却着实让我费劲心力. 如下: C ...
- Power BI 3-4月功能更新培训合集
Power BI 3-4月功能更新培训合集 Power BI每月功能的更新,都有很多大咖精辟解读,我们一直也都是积极中期待,相信所有P友如是或更甚. 视频学习可以结合微软Power BI 3-4月文 ...
- jdbc调用存储过程获取多个结果集
jdbc调用存储过程获取多个结果集 2017年07月26日 21:20:22 Kenny-Liu 阅读数:1486 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.cs ...
- JAVA基础知识之JDBC——JDBC事务处理及批量更新
JDBC事务 JDBC的事务由Connection提供,默认是打开的. 要开启事务,则要关闭自动提交, conn.setAutoCommit(false); 提交事务使用 conn.commit(); ...
- JavaEE JDBC 了解JNDI
了解JNDI @author ixenos Web与企业应用中的连接管理 1. 数据库连接方式: (1)使用配置文件 (2)使用JNDI 2. 在Web或企业环境中部署 JDBC应用时,数据库连接管理 ...
- JavaEE JDBC 事务
JDBC 事务 @author ixenos 事务 1.概念:我们将一组语句构建成一个事务(trans action),当所有语句顺利执行之后,事务可以被提交(commit):否则,如果其中某个语句遇 ...
- JavaEE JDBC RowSet行集
RowSet行集 @author ixenos 应用背景 1.基于结果集的缺点:在与用户的整个交互过程中,必须始终与数据库保持连接 后果:当用户长时间离开时,数据库连接长时间被占用,而这属于稀缺资源: ...
随机推荐
- Retinex系列之Frankle-McCann Retinex 分类: Matlab 图像处理 2014-12-01 21:52 538人阅读 评论(2) 收藏
一.Frankle-McCann Retinex Frankle-McCann算法选择一条螺旋结构的路径用于像素间的比较.如下图,算法沿着螺旋路径选取用于比较 像素点,这种路径选择包含了整个图像的全局 ...
- Python multiprocessing相关疑问
1. multiprocessing 和 threading有什么区别? threading module并没有真正利用多核.而multiprocessing 利用subprocess避开了pytho ...
- 事件模型的介绍与Button的ActionListener
事件监听: 这是个很重要的概念,也是个很重要的模型,vb,vc都是这样用,甚至后面学的web框架也在用. 现在我们可以做很多按钮了吧,但是我们的按钮按它是没反应的,现在我们来看看怎么样才能让它有 ...
- [完美方案+无懈可击]ubuntu 14.04(LTS) + GTX 980Ti显卡配置
安装好系统之后出现的问题: 1 不能上网:后来通过删除链接新建一个以太网链接(自动DHCP)重启莫名其妙就好使了. 2 分辨率只有两个:1024x ? 和 800x600. 分辨率低到让人头痛.通过查 ...
- 434 Number of Segments in a String 字符串中的单词数
统计字符串中的单词个数,这里的单词指的是连续的非空字符.请注意,你可以假定字符串里不包括任何不可打印的字符.示例:输入: "Hello, my name is John"输出: 5 ...
- 聊聊mq的使用场景
mq的作用 通过异步方式对系统解耦 增加系统的并发处理能力 通过异步方式对系统解耦 以用户注册为例,一般情况下: 分下一下,上面过程存在的一些问题: 注册过程会调用4个服务(注册服务.邮件服务.短信服 ...
- 实现通知栏Notification
课程Demo public class MainActivity extends Activity implements OnClickListener{ NotificationManager ma ...
- yii项目开发配置
Clone项目 git clone https://gitee.com/s***/dianshang.git 安装yii php ini 选择 [0] Development 安装扩展 copy co ...
- PHP正则表达式考察点
正则表达式的作用 分隔.查找.匹配.替换字符串 正则表达式的组成部分 分隔符 "/" . "#" . "~" 通用原子 \d : 十进制的0 ...
- 迅为工业级arm开发板i.MX6DL开发板软件硬件全开源
i.MX6是基于ARM Cortex™-A9架构的高扩展性多核系列应用处理器,促进了如高稳定性工业平板电脑.差异化智能本.前装车载中控系统和超高清电子书阅读器等新一代应用的发展.强劲的3D图形加速引擎 ...