java连接数据库ResultSet类(用于查询返回值)

复制代码
package com.ResultSet;

import javax.crypto.spec.OAEPParameterSpec;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;
import java.util.ArrayList;

public class demo1 {
    public static void main(String[] args)throws Exception {
        String url = "jdbc:mysql:///db";
        String name = "root";
        String passwd = "123";
        Connection conn = DriverManager.getConnection(url,name, passwd);

        //DQL查询语句
        //ResultSet其实就是执行对象执行executeQuery(sql)的结果 , 返回的是ResultSet类型的值(查询)
        //默认有个游标指向第一行(头行)
        //next() 1.将光标从当前位置向下移动一行 (2)判断当前行是否为有效行
        //getXxx(参数) 获取数据            (xxx)为数据类型
        //参数有两种形式
        //int:列的编号(从1开始) string(列的名称)

        String sql = "select *from account";
        Statement execute = conn.createStatement();
        ResultSet rs = execute.executeQuery(sql);

        //处理结果,遍历rs所有数据
        //光标向西移动一行,并且判断该当前是否有数据
        ArrayList<data_object> array = new ArrayList<>();
        while(rs.next()){
            //获取数据
            //单个获取
            int id =rs.getInt("id");
            String names = rs.getString("name");
            double money = rs.getDouble("money");
//            int id =rs.getInt(1);
//            String names = rs.getString(2);
//            double money = rs.getDouble(3);


            //封装获取 (自己根据情况定义一个对象,对象来获取每一行的值,再设定一个集合来储存对象,最后通过集合读出)
            data_object sign = new data_object(id,names,money);
            array.add(sign);



            System.out.println(id);
            System.out.println(names);
            System.out.println(money);
            System.out.println("-----------------");
        }
        rs.close();
        execute.close();
        conn.close();

        for (int i = 0; i < array.size(); i++) {
            System.out.println(array.get(i).toString());
        }
    }
}
相关推荐
yaoxin5211232 小时前
434. Java 日期时间 API - Period 基于日期的时间段
java·开发语言·python
何极光3 小时前
IDEA集成Maven
java·maven·intellij-idea
火山上的企鹅3 小时前
Codex实战:APP远程升级服务搭建(三)后台管理页面(APK 上传、版本管理、多应用页签)
服务器·网络·数据库·oracle·qgc
程序员二叉3 小时前
【JUC】ThreadLocal底层原理|内存泄漏|弱引用|跨线程传递方案
java·开发语言·面试·职场和发展·juc
程序员二叉3 小时前
【JUC】线程池全套深度详解|参数|流程|拒绝策略|调优|异常处理
java·开发语言·jvm·算法·面试·juc
老马识途2.03 小时前
在AI的帮助下理解spring的启动过程
java·前端·spring
青山木3 小时前
Hot 100 --- 轮转数组
java·数据结构·算法
阿狸猿4 小时前
论 NoSQL 数据库技术及其应用
数据库·nosql
FBI HackerHarry浩4 小时前
DataGrip2023.2.3默认保存的数据库和.sql文件在哪里?怎么修改默认路径?
数据库
袁小皮皮不皮4 小时前
3.HCIP OSPF补充知识(优化版)
服务器·网络·数据库·网络协议·智能路由器