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());
}
}
}
java连接数据库ResultSet类(用于查询返回值)
不会,就是不会!2023-10-04 11:55
相关推荐
笨拙的老猴子6 分钟前
[特殊字符] Java GC机制详解:G1、ZGC、Shenandoah全面解析与版本演进对比铭毅天下15 分钟前
Easysearch 版本进化全图——从 ES 国产替代到 AI Native 搜索数据库muddjsv21 分钟前
SQL 最常用技能详解与实战示例砍材农夫36 分钟前
物联网 基于netty构建mqtt协议规范(遗嘱与保留消息)DFT计算杂谈39 分钟前
KPROJ编译教程重生之我是Java开发战士1 小时前
【笔试强训】Week5:空调遥控, kotor和气球,走迷宫,主持人调度II,体操队形,二叉树的最大路径和,排序子序列,消减整数郑重其事,鹏程万里1 小时前
表达式计算器(mvel2)其实防守也摸鱼1 小时前
软件安全与漏洞--软件安全编码888CC++1 小时前
栈上分配 VS 堆分配 核心区别艾利克斯冰1 小时前
Java面试题汇总