① 向数据库发送SQL查询语句

首先使用Statement声明一个SQL语句对象,然后让已创建的连接对象con调用方法createStatement()创建SQL语句对象。

Statement sql = con.createStatement();

Connection con = null;

String DBname = "jdb"; //数据库名字

String url = "jdbc:mysql://localhost:3306/"+DBname+"?useSSL=true&characterEncoding=utf-8";

String username = "root";//数据库账号

String password = "root";//数据库密码

Statement sql = null;

try {

Class.forName("com.mysql.jdbc.Driver");

con = DriverManager.getConnection(url, username, password);//连接代码

sql = con.createStatement();

} catch (Exception e) {

// TODO: handle exception

System.out.println(e);

}

② 处理查询结果

有了SQL语句对象后,可以调用相应的方法实现对数据库中表的查询和修改,并将结果放在一个ResultSet类声明的对象中。换句话说,SQL查询语句对数据库的查询操作将返回一个ResultSet对象,ResultSet对象由按"列"(字段)组织的数据行构成。

ResultSet rs = sql.executeQuery("SELECT * FROM students");//查询student表中的数据

Connection con = null;

String DBname = "jdb"; //数据库名字

String url = "jdbc:mysql://localhost:3306/"+DBname+"?useSSL=true&characterEncoding=utf-8";

String username = "root";//数据库账号

String password = "root";//数据库密码

Statement sql = null;

ResultSet rs = null;

try {

Class.forName("com.mysql.jdbc.Driver");

con = DriverManager.getConnection(url, username, password);//连接代码

sql = con.createStatement();

rs = sql.executeQuery("SELECT * FROM students");//查询student表中的数据

} catch (Exception e) {

// TODO: handle exception

System.out.println(e);

}

ResultSet对象的方法

NO.

方法名称

类型

描述

01

public boolean next()throws SQLException

普通

将光标从当前位置向前移一行

02

public byte getByte(int columnIndex)throws SQLException

普通

以byte的形式获取当前行中指定列的值

03

public Date getDate(int columnIndex)throws SQLException

普通

以java.sql.Date对象的形式获取当前行中指定列的值

04

public double getDouble(int columnIndex)throws SQLException

普通

以double的形式获取此 当前行中指定列的值

05

public float getFloat(int columnIndex)throws SQLException

普通

以float的形式获取当前行中指定列的值

06

public int getInt(int columnIndex)throws SQLException

普通

以int的形式获取当前行中指定列的值

07

public long getLong(int columnIndex)throws SQLException

普通

以long的形式获取当前行中指定列的值

08

public String getString(int columnIndex)throws SQLException

普通

以String的形式获取当前行中指定列的值

09

public byte getByte(String columnName)throws SQLException

普通

以byte的形式获取当前行中指定列的值

10

public Date getDate(String columnName)throws SQLException

普通

以java.sql.Date对象的形式获取当前行中指定列的值

11

public double getDouble(String columnName)throws SQLException

普通

以double的形式获取此 当前行中指定列的值

12

public float getFloat(String columnName)throws SQLException

普通

以float的形式获取当前行中指定列的值

13

public int getInt(String columnName)throws SQLException

普通

以int的形式获取当前行中指定列的值

14

public long getLong(String columnName)throws SQLException

普通

以long的形式获取当前行中指定列的值

15

public String getString(String columnName)throws SQLException

普通

以String的形式获取当前行中指定列的值

说明:

无论字段是何种属性;都可以使用getString方法返回字段值的串表示

③ 关闭连接

con.close();

注:使用ResultSet对象中的数据时,必须始终保持数据库的连接,直到应用程序将ResultSet对象中的数据查看完毕。如果在rs之后立即关闭连接,那么程序将无法获取rs中的数据。

范例:控制statement对象游标

方法:public Statement createStatement(int resultSetType,int resultSetConcurrency) throws SQLException

//获取Statement对象

Statement stmt = con.createStatement(int type,int concurrency);

//返回结果集

ResultSet rs = stmt.executeQuery(SQL语句);

resultSetType - 结果集类型,

resultSetType:ResultSet.TYPE_FORWARD_ONLY、ResultSet.TYPE_SCROLL_INSENSITIVE 或 ResultSet.TYPE_SCROLL_SENSITIVE

resultSetConcurrency:ResultSet.CONCUR_READ_ONLY 或 ResultSet.CONCUR_UPDATABLE

ResulSet常用方法

NO.

方法名称

类型

描述

01

public void beforeFirst()throws SQLException

普通

将光标移动到开头,位于第一行之前

02

public void afterLast()throws SQLException

普通

将光标移动到末尾,位于最后一行之后

03

public boolean first()throws SQLException

普通

将光标移动到第一行

04

public boolean last()throws SQLException

普通

将光标移动到最后一行

05

public boolean isBeforeFirst()throws SQLException

普通

获取光标是否位于第一行之前

06

public boolean isAfterLast()throws SQLException

普通

获取光标是否位于最后一行之后

07

public boolean isFirst()throws SQLException

普通

获取光标是否位于第一行

08

public boolean isLast()throws SQLException

普通

获取光标是否位于最后一行。调用 isLast 方法可能开销很大

09

public int getRow()throws SQLException

普通

获取当前行编号

10

public boolean absolute(int row)throws SQLException

普通

将光标移动到此 ResultSet 对象的给定行编号

注:如果row取负值,就是倒数的行数,absolute(-1)表示移到最后一行,absolute(-2)表示倒数第二行。

02、JDBC查询的更多相关文章

  1. Java 通过JDBC查询数据库表结构(字段名称,类型,长度等)

    Java 通过JDBC查询数据库表结构(字段名称,类型,长度等) 发布者:唛唛家的豆子   时间:2012-11-20 17:54:02   Java 通过JDBC查询数据库表结构(字段名称,类型,长 ...

  2. spring jdbc 查询结果返回对象、对象列表

    首先,需要了解spring jdbc查询时,有三种回调方式来处理查询的结果集.可以参考 使用spring的JdbcTemplate进行查询的三种回调方式的比较,写得还不错. 1.返回对象(queryF ...

  3. 【T-SQL基础】02.联接查询

    概述: 本系列[T-SQL基础]主要是针对T-SQL基础的总结. [T-SQL基础]01.单表查询-几道sql查询题 [T-SQL基础]02.联接查询 [T-SQL基础]03.子查询 [T-SQL基础 ...

  4. 用JDBC查询数据库

    JDBC API的核心组件:1.DriverManager类:用语跟踪可用的JDBC驱动程序并产生数据库连接. 2.Connection接口:用于取得数据库信息.生成数据库语句,并管理数据库事务. 3 ...

  5. Redis查询&JDBC查询&Hibernate查询方式的效率比较...

    比较三种查询方式查询效率对比...我是用的JavaWeb的方式通过通过JSP页面查询的填写查询的参数...给予反馈.... 整个demo的下载地址:http://files.cnblogs.com/f ...

  6. JDBC 查询的三大参数 setFetchSize prepareStatement(String sql, int resultSetType, int resultSetConcur)

    JDBC 查询的三大参数 本文转载至 http://blog.csdn.net/turkeyzhou/article/details/5115228 DBC1.0 .JDBC2.0 .JDBC3.0  ...

  7. JDBC查询实例

    作为Java与数据库交互最古老的.最基础的规范,JDBC提供了访问底层数据库的接口,其他ORM框架都是在JDBC这块基石上构建的.下面我们看一个基本的JDBC查询例子: package com.ins ...

  8. 使用jdbc查询防止出现中文乱码的方法

    在使用mysql创建数据库及表格,在navicat中可以正常查询出中文,但使用jdbc查询的结果中,中文为乱码. 网上查到资料,为了能够彻底一劳永逸的解决这个问题,需要修改mysql下配置文件my.i ...

  9. JDBC 查询 模板

    JDBC 查询 与增删改不同的是SQL语句的不同,还有查询反回的是结果集  需要定义 利用 next()方法逐层查询数据 使用getXXX方法获取数据 代码相关参数根据个人设置进行修改!!!! pac ...

随机推荐

  1. 关于UE4音效的一些小问题

    前言 前几天实在忍受不了StarterContent默认音效的折磨,去网上翻罗了一下初中时很着迷的游戏<Bounce-Tales>的音效,在导入音效时出了点问题,特此说明一下解决方案,希望 ...

  2. 《SQL Server 2008 R2》 收缩数据库日志文件

    USE [master] GO /****** Object: StoredProcedure [dbo].[pro_Shrink_Log] Script Date: 2019/8/16 16:56: ...

  3. 语义分析的waf 目前就看到长亭 机器学习的waf有fortnet 阿里云的waf也算

    近期,在全球权威咨询机构 Gartner 发布的 2019 Web 应用防火墙魔力象限中,阿里云 Web 应用防火墙成功入围,是亚太地区唯一一家进入该魔力象限的厂商! Web 应用防火墙,简称 WAF ...

  4. sql注入知识点

    需找sql注入点1\无特定目标inurl:.php?id= 2\有特定目标:inurl:.php?id= site:target.com 3\工具爬取spider,对搜索引擎和目标网站的链接进行爬取 ...

  5. 多线程中fork与mutex

    在多线程程序中fork出一个新进程,发现新的进程无法正常工作.因为:在使用fork时会将原来进程中的所有内存数据复制一份保存在子进程中.但是在拷贝的时候,但是线程是无法被拷贝的.如果在原来线程中加了锁 ...

  6. springboot+springmvc拦截器做登录拦截

    springboot+springmvc拦截器做登录拦截 LoginInterceptor 实现 HandlerInterceptor 接口,自定义拦截器处理方法 LoginConfiguration ...

  7. SWA2G422&485JK2G基础篇: STM32+W5500实现MQTT通信控制,485/422透传通信

    说明 这节实现的功能: STM32+W5500实现MQTT通信控制 细节功能: 1.DHCP动态获取IP 2.DNS域名解析 3.网口<--MQTT-->485/422透传通信 测试准备工 ...

  8. HTTP协议COOKIE和SESSION有什么区别

    1.为什么会有COOKIE这种机制 首先一种场景, 在一个网站上面, 我发起一次请求,那服务器怎么知道我是谁?是谁发起的这次请求呢,  HTTP协议是无状态的协议, 浏览器的每一次请求,服务器都当做一 ...

  9. [ Python入门教程 ] Python的控制语句

    Python控制语句由条件语句.循环语句构成.控制语句根据条件表达式控制程序的流转.本章将介绍Python中控制语句的基本语法. 条件判断语句 (1)if条件语句 if语句用于检测某个条件是否成立.如 ...

  10. java if 条件语句

    import java.util.Scanner; public class Sample { public static void main(String[] args) { int num; Sc ...