Eclipse中java获得mysql的查询结果集

不废话,先上代码,再上解释说明

 1 package com.ningmeng;
 2 
 3 import java.sql.*;
 4 /**
 5  * 1:获取查询结果集
 6  * @author biexiansheng
 7  *
 8  */
 9 public class Test03 {
10 
11     public static void main(String[] args) {
12         try {
13             Class.forName("com.mysql.jdbc.Driver");
14             System.out.println("加载数据库驱动成功");
15             String url="jdbc:mysql://localhost:3306/test";//声明数据库test的url
16             String user="root";//数据库账号
17             String pass="123456";//数据库密码
18             //建立数据库连接,获得连接对象conn
19             Connection conn=DriverManager.getConnection(url,user,pass);
20             System.out.println("数据库连接成功");
21             Statement stmt=conn.createStatement();//创建一个Statement对象
22             String sql="select * from users";//生成一条sql语句
23             ResultSet rs=stmt.executeQuery(sql);//执行查询,把查询结果赋值给结果集对象
24             int id,age,sex;//声明3个变量分别为id,age,sex
25             String username,password;//声明2个变量分别为用户名,密码
26             System.out.println("id\t 用户名\t 密码 \t  年龄\t 性别");//其中\t相当于8个空格
27             while(rs.next()){//遍历结果集
28                 id=rs.getInt("id");//获得id
29                 username=rs.getString(2);//
30                 password=rs.getString("password");//
31                 age=rs.getInt(4);//
32                 sex=rs.getInt(5);//
33                 System.out.println(id+"\t"+username+"\t"+password+"\t"+age+"\t"+
34                         sex+"\t");
35             }
36             System.out.println("获得查询结果集");
37             conn.close();
38             System.out.println("关闭数据库连接对象");
39         } catch (ClassNotFoundException e) {
40             // TODO Auto-generated catch block
41             e.printStackTrace();
42         }//加载数据库驱动
43         catch (SQLException e) {
44             // TODO Auto-generated catch block
45             e.printStackTrace();
46         }
47     
48         
49     }
50 }

结果如下所示

1:Result接口类似于一个临时表,用来暂时存放数据库查询操作所获得的结果集。

2:PreparedStatement接口中的excuteQuery()方法,在此PreparedStatement对象执行sql查询语句,返回结果为查询结果集Result对象

3:next()将指针向下移一行

4:ResultSet对象的getXXX()方法可获取查询结果集中数据。由于ResultSet中保存的数据是表的形式,因此可通过使用getXXX()方法指定列的序号与列的名称。

id=rs.getInt("id");//获得id

username=rs.getString(2);//

password=rs.getString("password");//

age=rs.getInt(4);//

sex=rs.getInt(5);//

仔细体会就可以明白,getXXX(参数);参数既可以是列的名称还可以是第几列的数字。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏贾鹏辉的技术专栏@CrazyCodeBoy

【Android开发高级实践】轻松帮你发现Bug(FindBugs在AndroidStudio上的应用)

  在日常开发过程中难免会因为一时疏忽而留下一些Bug,这些Bug就是埋在程序里的定时炸弹,如果不能及时铲除就会导致程序的不稳定,异常或闪退的现象,从而导致用户...

2866
来自专栏知识分享

(一)Lua脚本语言入门

今天开始自己的Lua语言学习,Lua脚本语言,是介于应用程序和开发其应用程序的底层编程语言之间,,它很方便调用其它语言,它只是在载入时对其进行编译,而不像我们写...

3347
来自专栏MasiMaro 的技术博文

OLEDB存取BLOB型数据

现代数据库系统除了支持一些标准的通用数据类型以外,大多数还支持一种称之为BLOB型的数据。 BLOB全称为big large object bytes, 大二...

983
来自专栏JavaQ

Java研发方向如何准备BAT技术面试答案(上)

最近因为忙于工作,没时间整理,本篇是下班后晚上抽空整理的,文中部分答案本来是想自己好好整理一份的,但是时间真的很紧,所以就整理了一下网络上的文章链接,挑了写的不...

3345
来自专栏kl的专栏

skywalking源码分析之javaAgent工具ByteBuddy的应用

关于skywalking请看我上一篇博文,其使用javaAgent技术,使得应用接入监控0耦合。今天在分析skywaking过程中,对javaAgent技术有了...

5188
来自专栏林冠宏的技术文章

java 连接数据库之一个完整的函数

第一个参数要查询的列名 第二个参数是连接的url 第三个参数是用户名 第四个参数密码 第五个参数是执行的命令。 注意,url格式是 jdbc:mysql://l...

1808
来自专栏zhisheng

Java研发方向如何准备BAT技术面试答案(上)

1. 面向对象和面向过程的区别 面向过程 优点:性能比面向对象高,因为类调用时需要实例化,开销比较大,比较消耗资源;比如单片机、嵌入式开发、Linux/Un...

4044
来自专栏Ldpe2G的个人博客

Scala typeclass 设计模式

1016
来自专栏Java3y

Struts2【拦截器】

什么是拦截器 拦截器Interceptor…..拦截器是Struts的概念,它与过滤器是类似的…可以近似于看作是过滤器 为什么我们要使用拦截器 前面在介绍Str...

2875
来自专栏Java后端生活

JDBC(三)PreparedStatement

SQL 注入是利用某些系统没有对用户输入的数据进行充分的检查,而在用户输入数据中注入非法的 SQL 语句段或命令,从而利用系统的 SQL 引擎完成恶意行为的做法

571

扫码关注云+社区