JDBC中resutset接口操作实例详解

作者:无名 - 数据库其它 -

本文主要向大家展示JDBC接口中resutset接口的用法实例,下面我们看看具体内容。

1. ResultSet细节1

功能:封锁结果集数据

操作:如何获得(取出)结果

package com.sjx.a;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;
import org.junit.Test;
  //1. next方法,向下移动并判断是否有内容
  //2. getXXX方法,根据列索引或列名获得列的内容
public class Demo {
  @Test
  public void fun1() throws Exception{
    //1 注册驱动
    Class.forName("com.mysql.jdbc.Driver");
    //2 获得连接
    Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/day05", "root", "1234");
    //3 创建Statement
    Statement st = conn.createStatement();
    //4 书写sql
    String sql = "select * from t_user" ;
    //5 执行sql
    ResultSet rs = st.executeQuery(sql);
    //向下移动一行,并判断
    while(rs.next()){
      //有数据
      //取数据:getXXX 
      int id = rs.getInt(1);//获得第一列的值
      //int id rs.getInt("id");// 获得id列的值
      String name = rs.getString(2);//获得第二列的值
      int age = rs.getInt(3);//获得第三列的值
      System.out.println(id+"==>"+name+"==>"+age);
      
      //rs.gettimestamp(columnIndex)
    }
    //6关闭资源
   st.close();
   conn.close();
  }
  /* 数据库类型      java类型
    int         int
    double       double
    decimal       double
    char       String
    varchar       String
    datetime     Date
    timestamp    Timestamp/Date
   */
}

2.ResultSet细节2

结果集的滚动-->移动结果集的指针就是滚动

结果集反向修改数据库

package com.sjx.a;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;
import org.junit.Test;
public class Demo2 {
  @Test
  public void fun1() throws Exception{
    //1 注册驱动
    Class.forName("com.mysql.jdbc.Driver");
    //2 获得连接
    Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/day05", "root", "1234");
    //3 创建Statement
    Statement st = conn.createStatement();
    //4 书写sql
    String sql = "select * from t_user" ;
    //5 执行sql
    ResultSet rs = st.executeQuery(sql);
    //倒着遍历
      //1> 光标移动到最后一行之后
      rs.afterLast();
      //2> 遍历=>
      while(rs.previous()){//向上移动光标,并判断是否有数据
        int id = rs.getInt("id");// 获得id列的值
        String name = rs.getString("name");//获得第二列的值
        int age = rs.getInt("age");//获得第三列的值
        System.out.println(id+"==>"+name+"==>"+age);
      }
    //6关闭资源
   st.close();
   conn.close();
  }
  /* 数据库类型      java类型
    int         int
    double       double
    decimal       double
    char       String
    varchar       String
    datetime     Date
    timestamp    Timestamp/Date
   */
}

3.使用ResultSet修改记录

package com.sjx.a;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;
import org.junit.Test;
//ResultSet细节
// 2.结果集反向修改数据库
public class Demo3 {
  @Test
  public void fun1() throws Exception{
    //1 注册驱动
    Class.forName("com.mysql.jdbc.Driver");
    //2 获得连接
    Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/day05", "root", "1234");
    //3 创建Statement
    Statement st = conn.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_UPDATABLE);
    //4 书写sql
    String sql = "select * from t_user" ;
    //5 执行sql
    ResultSet rs = st.executeQuery(sql);
    //使用结果集 反向修改数据库
    rs.next();//将光标移动到第一行
    rs.updateString("name", "汤姆");// 修改第一行name列的值为中文汤姆
    rs.updateRow();// 确认修改
    //6关闭资源
   st.close();
   conn.close();
  }
}

总结

以上就是本文关于JDBC中resutset接口操作实例详解的全部内容了,希望对大家有所帮助。有兴趣的朋友欢迎参阅更多有关JDBC的文章:BaseJDBC和CRUDDAO的写法实例代码、Spring jdbc中数据库操作对象化模型的实例详解、Java基于jdbc连接mysql数据库操作示例等,在此也希望大家对网站多多支持!

这篇内容就是由IT人知识库 小编为各位整理 原文链接:http://www.itpeo.net/12848/499954.html





JDBC常用接口总结

本文主要向大家介绍JDBC常用的接口都有哪些,下面来看看具体内容。 1.Driver接口 对于每一个数据库驱动程序都必... ...

Mybatis分页插件的实例详解

Mybatis分页插件的实例详解 1.前言: 我们知道,在MySQL中,分页的sql是使用limit来做,如果我们自己... ...

将sqlite3中数据导入到mysql中的实战教程

前言 sqlite3只小巧轻便,但是并不支持并发访问,当网站并发量较大时候,数据库请求队列边长,有可能导致队列末尾去数据... ...

rfedfre

sql连接查询语句中on、where筛选的区别总结

前言 相信对于每位程序员来说,sql查询这个东西, 要说它简单, 可以很简单, 通常情况下只需使用增删查改配合编程语言的... ...

利用DataSet部分功能实现网站登录

首先,我之前必须完成过注册,并把个人信息存入数据库中。 其次,这部分的个别对象是存于某些文档中的,需要引用命名空间。 ... ...

MyBatis获取数据库自生成的主键Id详解及实例代码

MyBatis获取数据库自生成的主键Id详解及实例代码 在使用MySQL数据库时我们一般使用数据库的自增主键自动产生主键... ...

rfedfre

解决MongoVUE的Collections数据不显示的问题

问题描述:   使用 mongoDB数据库, 数据添加成功了,使用命令行能查询出来,但在MongoVUE 中数据却不显示... ...

常用SQL语句优化技巧总结【经典】

本文实例总结了常用SQL语句优化技巧。分享给大家供大家参考,具体如下: 除了建立索引之外,保持良好的SQL语句编写习惯将... ...

详解 MapperScannerConfigurer之sqlSessionFactory注入方式

MapperScannerConfigurer之sqlSessionFactory注入方式讲解 首先,Mybatis中的... ...

MySQL与Oracle SQL语言差异比较一览

数据类型 编号 ORACLE MYSQL 注释... ...

浅谈数据库索引的作用及原理

数据库索引是为了增加查询速度而对表字段附加的一种标识。很多人机械的理解索引的概念,认为增加索引只有好处没有坏处。其实远不... ...

rfedfre

hive函数简介

首先我们要知道hive到底是做什么的。下面这几段文字很好的描述了hive的特性:   1.hive是基于Hadoop的... ...

数据库服务器构建和部署检查列表详解

前言 我们可能经常安装和部署数据库服务器,但是可能突然忘记了某个设置,为后来的运维造成隐患。下面是国外大牛整理的的检查... ...

rfedfre

利用SQL脚本导入数据到不同数据库避免重复的3种方法

前言 相信大家都有所体会,无论何种语言,一旦看见代码中有重复性的代码则想到封装来复用,在SQL同样如此,若我们没有界面... ...

浅谈数据库事务四大特性

数据库四大特性分别是:原子性、一致性、分离性、持久性。下面我们看看具体介绍。 原子性   事务的原子性指的是,事务中... ...

SQL注入原理与解决方法代码示例

一、什么是sql注入? 1、什么是sql注入呢?      &nb... ...

远程数据库的表超过20个索引的影响详细解析

昨天同事参加了一个研讨会,有提到一个案例。一个通过dblink查询远端数据库,原来查询很快,但是远端数据库增加了一个索引... ...

rfedfre

你应该知道的States字段使用规范

前言 最近在工作中了遇到了一些内容,觉着有必要和大家分享下,我们为了统一数据库表的状态字段,统一数据库表设计,简化字段在... ...

rfedfre

200行代码轻松实现一个简单的区块链

英文原文:Lauri Hartikka 区块链的基础概念很简单:一个分布式数据库,存储一个不断加长的 list,list... ...

rfedfre

14张图看懂什么是区块链技术

区块链技术最初源于解决“拜占庭将军”问题,金融科技的发展使得区块链技术有了更好的应用场景。它最显著的特征是去中心化,当然... ...