管理结果集

  JDBC使用ResultSet来封装查询到的结果集,然后移动记录指针来取出结果集的内容,除此之外,JDBC还允许通过ResultSet来更新记录,并提供了ResultSetMetaData来获取ResultSet对象的相关信息。

可滚动的结果集.

ResultSet接口中的方法:

  boolean next():将光标向下移动一行,

  boolean absolute(int row):将光标移动到指定的行。

  void afterLast():移动到结果集的末尾,既最后一行的末尾。

  void beforeFirst(): 将光标移动到结果集的开头,既第一行的前面。

  boolean previous():将光标移动到上一行

  boolean last():将光标移动到最后一行

可滚动可更新的结果集:

  ResultSet定位指针的方法有很多,但是只使用了next方法来移动指针,实际上也可以使用其他方法来移动指针,使用absolute(),previous(),afterLast()等方法自由移动指针的结果集被称为可滚动的结果集。

  在JDK1.4之前,默认打开的ResultSet是不可以滚动的,必须在创建Statement或者PrepareStatement时传入额外的参数,从Java5.0以后,默认打开的ResultSet就是可滚动的结果集,无需传入额外ide参数。

  以默认方法打开的结果集是不可更新的,如果希望创建可更新的结果集,则必须在创建Statement或者PrepareStatement时传入额外的参数,Connection在创建Statement或者Prepared Statement时还可以传入如下的两个参数。

  ResultSetType:控制ResultSet的类型,该参数的取值可以取如下三个值(指定结果集是否可滚动,是否敏感):

    ResultSet.TYPE_FORWARD_ONLY:该常量控制指针只能向前移动,只是JDK1.4以前的默认值。

    ResultSet.TYPE_SCROLL_INSENSITIVE:该常量控制指针可自由移动,但是地底层的数据改变是不会影响ResultSet的内容(既数据库的变化时不会影响结果集的);

    ResultSet.TYPE_SCROLL_SENSITIVE:该常量控制指针可以自由移动,但是底层的数据改变是会影响结果集的内容。

  resultSetConcBLEurrency:控制ResultSet的并发类型,该参数有两个(是否可更新):

    ResultSet.CONCUR_READ_ONLY:该常量指示结果集是只读的并发模式(默认);

    ResultSet.CONCUR_UPDATA:该常量指示结果集是可更新的并发模式

使用ResultSetMateDate分析结果集

  当执行SQL查询后可通过移动记录指针来遍历ResultSet的每条记录,但是程序可能不清楚该结果集中包含哪些数据列,以及每个数据列的数据类型,那么可通过ResultSetMateDate来获取关于ResultSet的描述信息。

  MetaData的意思是元数据,既描述其他数据类型的数据,因此ResultSetMateDate封装了描叙ResultSet对象的数据;

  ResultSet里包含了一个getMetaData()的方法,该方法返回ResultSet对应的ResultMataData对象,一但获取了ResultSet的ResultSetMetaData对象,就可以通过ResultSetMetaData来返回ResultSet的描述信息。常用的方法有三个:

    int getColumnCount():返回该ResultSet的列数量。

    String getColumnName(int column):返回指定索引的列名;

    int getColumnType(int column):返回指定索引的列类型;

  虽然ResultSetMetaDate可以准确的分析出ResultSet里包含了多少列,以及每列的数据类型和每列的名称,但是使用该对象是需要一定的系统开销的,没有必要的话就不要使用此对象了。

  

javaweb学习——JDBC(五)的更多相关文章

  1. javaweb学习总结(五)——Servlet开发(一)

    一.Servlet简介 Servlet是sun公司提供的一门用于开发动态web资源的技术. Sun公司在其API中提供了一个servlet接口,用户若想用发一个动态web资源(即开发一个Java程序向 ...

  2. (转载)JavaWeb学习总结(五十)——文件上传和下载

    源地址:http://www.cnblogs.com/xdp-gacl/p/4200090.html 在Web应用系统开发中,文件上传和下载功能是非常常用的功能,今天来讲一下JavaWeb中的文件上传 ...

  3. JavaWeb学习总结(五十)——文件上传和下载

    在Web应用系统开发中,文件上传和下载功能是非常常用的功能,今天来讲一下JavaWeb中的文件上传和下载功能的实现. 对于文件上传,浏览器在上传的过程中是将文件以流的形式提交到服务器端的,如果直接使用 ...

  4. javaweb学习总结(五)——Servlet开发(一)(转)

    转载自 http://www.cnblogs.com/xdp-gacl/p/3760336.html 一.Servlet简介 Servlet是sun公司提供的一门用于开发动态web资源的技术. Sun ...

  5. JavaWeb学习笔记五 会话技术Cookie&Session

    什么是会话技术? 例如网站的购物系统,用户将购买的商品信息存储到哪里?因为Http协议是无状态的,也就是说每个客户访问服务器端资源时,服务器并不知道该客户端是谁,所以需要会话技术识别客户端的状态.会话 ...

  6. JavaWeb学习总结(五十二)——使用JavaMail创建邮件和发送邮件

    一.RFC882文档简单说明 RFC882文档规定了如何编写一封简单的邮件(纯文本邮件),一封简单的邮件包含邮件头和邮件体两个部分,邮件头和邮件体之间使用空行分隔. 邮件头包含的内容有: from字段 ...

  7. (转载)JavaWeb学习总结(五十三)——Web应用中使用JavaMail发送邮件

    博客源地址:http://www.cnblogs.com/xdp-gacl/p/4220190.html 现在很多的网站都提供有用户注册功能, 通常我们注册成功之后就会收到一封来自注册网站的邮件.邮件 ...

  8. (转载)JavaWeb学习总结(五十二)——使用JavaMail创建邮件和发送邮件

    博客源地址:http://www.cnblogs.com/xdp-gacl/p/4216311.html 一.RFC882文档简单说明 RFC882文档规定了如何编写一封简单的邮件(纯文本邮件),一封 ...

  9. (转载)JavaWeb学习总结(五十一)——邮件的发送与接收原理

    博客源地址:http://www.cnblogs.com/xdp-gacl/p/4209586.html 一. 邮件开发涉及到的一些基本概念 1.1.邮件服务器和电子邮箱 要在Internet上提供电 ...

随机推荐

  1. SpringBoot#Download

    _amaze! 如果不使用fastdfs等分布式的文件存储,有时候还是需要上传文件到web应用所在的服务器的磁盘上,下载文件.下面是一个小demo,关于如何用控制器进行上传和下载. - @PostMa ...

  2. kafka的编程模型

    1.kafka消费者编程模型 分区消费模型 组(group)消费模型 1.1.1.分区消费架构图,每个分区对应一个消费者. 1.1.2.分区消费模型伪代码描述 指定偏移量,用于从上次消费的地方开始消费 ...

  3. vue作用域插槽实践

    引言 我在练手的时候发现后端返回的数据可以通过两种方式渲染 (自己遇到的 可能你都会 哈哈哈) 后端传过来的数据函数 from django.http import JsonResponse def ...

  4. 基于Ambari的WebUI部署HBase服务

    基于Ambari的WebUI部署HBase服务 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.部署Ambari服务 博主推荐阅读: https://www.cnblogs.co ...

  5. ABP框架没有httpPost,httpget,httpput特性

    需要引用一下组件, Microsoft.AspNetCore.Mvc

  6. Hadoop家族系统学习路线

    本文主要介绍Hadoop家族产品,常用的项目包括Hadoop,Hive,Pig,HBase,Sqoop,Mahout,Zookeeper,Avro,Ambari,Chukwa,新增加的项目包括,YAR ...

  7. foreach —(遍历数组或循环中的字符,以获取信息)

    namespace ConsoleApplication2{ class Program {//letter 字母 gigit 数字 symbol 符号 static void Main(string ...

  8. 实验吧Web-难-貌似有点难(http头欺骗)

    有关一些http头,参考:https://blog.csdn.net/zz_Caleb/article/details/84147066 打开链接:点击view source看到一段代码 <?p ...

  9. day23(023-递归练习)

    23.01_File类递归练习(统计该文件夹大小) * 需求:1,从键盘接收一个文件夹路径,统计该文件夹大小(字节?) * * 从键盘接收一个文件夹路径 * 1,创建键盘录入对象 * 2,定义一个无限 ...

  10. NET CLR via C#(第4版)第4章 类型基础

    本章内容: 1 所有类型都从System.Object派生 2 类型转换 3 命名空间和程序集 4 运行时的相互关系   本章讲述使用类型和CLR时需掌握的基础知识.具体地说,要讨论所有类型都具有的一 ...