JDBC查询详解

一、JDBC查询语句

JDBC查询是Java中对关系型数据库进行查询操作的方式之一。在JDBC查询中,我们需要进行以下步骤:

1、加载驱动程序:

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

2、创建连接:

String url = "jdbc:mysql://localhost:3306/test";
Connection conn = DriverManager.getConnection(url, "root", "123456");

3、创建Statement对象:

Statement stmt = conn.createStatement();

4、执行查询操作:

ResultSet rs = stmt.executeQuery("SELECT * FROM student");

5、处理查询结果:

while(rs.next()) {
    int id = rs.getInt("id");
    String name = rs.getString("name");
    System.out.println("id:" + id + ",name:" + name);
}

二、JDBC子查询

JDBC子查询是指在查询语句中嵌套了另外一条完整的SELECT语句,根据内外两个查询之间的关系,将其分为以下几种类型:

1、相关子查询:外部查询中的每一条记录都能够和内部查询中的数据进行比较,并进行筛选。

SELECT * FROM student WHERE grade > (SELECT AVG(grade) FROM student);

2、不相关子查询:内部查询和外部查询没有直接联系,每次内部查询只返回一条结果。

SELECT name,(SELECT COUNT(*) FROM score WHERE score.student_id = student.id) as count FROM student;

三、JDBC查询数据库

JDBC查询数据库主要包括以下几种操作:

1、获取全部数据库:

ResultSet rs = stmt.executeQuery("SHOW DATABASES");

2、获取所有数据表:

ResultSet rs = stmt.executeQuery("SHOW TABLES");

3、获取数据表的元数据信息:

DatabaseMetaData metaData = conn.getMetaData();
ResultSet rs = metaData.getColumns(null, null, "student", null);

四、原生JDBC进行大数据量查询

原生JDBC进行大数据量查询时需要注意以下几点:

1、设置每次查询的数据量:

stmt.setFetchSize(1000);

2、使用游标方式查询数据:

ResultSet rs = stmt.executeQuery("SELECT * FROM student",ResultSet.TYPE_FORWARD_ONLY, ResultSet.CONCUR_READ_ONLY);
stmt.setFetchSize(Integer.MIN_VALUE);

3、手动关闭ResultSet和Statement:

stmt.close();
rs.close();

五、JDBC查询数据

JDBC查询数据的操作包括以下几种类型:

1、单条件查询:

ResultSet rs = stmt.executeQuery("SELECT * FROM student WHERE grade > 90");

2、多条件查询:

PreparedStatement pstmt = conn.prepareStatement("SELECT * FROM student WHERE grade > ? AND gender = ?");
pstmt.setInt(1, 90);
pstmt.setString(2, "male");
ResultSet rs = pstmt.executeQuery();

3、范围查询:

PreparedStatement pstmt = conn.prepareStatement("SELECT * FROM student WHERE grade BETWEEN ? AND ?");
pstmt.setInt(1, 80);
pstmt.setInt(2, 90);
ResultSet rs = pstmt.executeQuery();

六、JDBC模糊查询带号

JDBC模糊查询带号主要通过LIKE关键字进行查询:

PreparedStatement pstmt = conn.prepareStatement("SELECT * FROM student WHERE name LIKE ?");
pstmt.setString(1, "%三%");
ResultSet rs = pstmt.executeQuery();

七、JDBC查询数量

JDBC查询数量主要通过聚合函数COUNT进行查询:

ResultSet rs = stmt.executeQuery("SELECT COUNT(*) FROM student");

八、京东JDBC物流查询

京东JDBC物流查询是指通过JDBC查询京东物流信息的操作。具体步骤如下:

1、登录京东开放平台,获取appkey和appsecret。

2、在代码中调用京东开放平台的API接口获取到物流信息。

String url = "https://way.jd.com/JDCloud/mobileaddress";
String appkey = "your_appkey";
String appsecret = "your_appsecret";
String param = "mobile=18600000000&appkey=" + appkey;
String sign = DigestUtils.md5Hex(param + appsecret);
url = url + "?" + param + "&sign=" + sign;

URL obj = new URL(url);
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("GET");

BufferedReader in = new BufferedReader(new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();

while ((inputLine = in.readLine()) != null) {
    response.append(inputLine);
}
in.close();

3、使用JSON解析库解析返回的JSON字符串。

JSONObject json = new JSONObject(response.toString());
JSONArray result = json.getJSONArray("result");

4、将结果保存到数据库中。

PreparedStatement pstmt = conn.prepareStatement("INSERT INTO logistics (order_id, status, update_time) VALUES (?, ?, ?)");
pstmt.setString(1, "123456");
pstmt.setString(2, result.getJSONObject(0).getString("Status"));
pstmt.setString(3, result.getJSONObject(0).getString("UpdateTime"));
int rows = pstmt.executeUpdate();

原创文章,作者:DYGJ,如若转载,请注明出处:https://www.506064.com/n/135152.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
DYGJDYGJ
上一篇 2024-10-04 00:10
下一篇 2024-10-04 00:10

相关推荐

  • Linux sync详解

    一、sync概述 sync是Linux中一个非常重要的命令,它可以将文件系统缓存中的内容,强制写入磁盘中。在执行sync之前,所有的文件系统更新将不会立即写入磁盘,而是先缓存在内存…

    编程 2025-04-25
  • 神经网络代码详解

    神经网络作为一种人工智能技术,被广泛应用于语音识别、图像识别、自然语言处理等领域。而神经网络的模型编写,离不开代码。本文将从多个方面详细阐述神经网络模型编写的代码技术。 一、神经网…

    编程 2025-04-25
  • Python输入输出详解

    一、文件读写 Python中文件的读写操作是必不可少的基本技能之一。读写文件分别使用open()函数中的’r’和’w’参数,读取文件…

    编程 2025-04-25
  • git config user.name的详解

    一、为什么要使用git config user.name? git是一个非常流行的分布式版本控制系统,很多程序员都会用到它。在使用git commit提交代码时,需要记录commi…

    编程 2025-04-25
  • Linux修改文件名命令详解

    在Linux系统中,修改文件名是一个很常见的操作。Linux提供了多种方式来修改文件名,这篇文章将介绍Linux修改文件名的详细操作。 一、mv命令 mv命令是Linux下的常用命…

    编程 2025-04-25
  • 详解eclipse设置

    一、安装与基础设置 1、下载eclipse并进行安装。 2、打开eclipse,选择对应的工作空间路径。 File -> Switch Workspace -> [选择…

    编程 2025-04-25
  • C语言贪吃蛇详解

    一、数据结构和算法 C语言贪吃蛇主要运用了以下数据结构和算法: 1. 链表 typedef struct body { int x; int y; struct body *nex…

    编程 2025-04-25
  • Python安装OS库详解

    一、OS简介 OS库是Python标准库的一部分,它提供了跨平台的操作系统功能,使得Python可以进行文件操作、进程管理、环境变量读取等系统级操作。 OS库中包含了大量的文件和目…

    编程 2025-04-25
  • MPU6050工作原理详解

    一、什么是MPU6050 MPU6050是一种六轴惯性传感器,能够同时测量加速度和角速度。它由三个传感器组成:一个三轴加速度计和一个三轴陀螺仪。这个组合提供了非常精细的姿态解算,其…

    编程 2025-04-25
  • Java BigDecimal 精度详解

    一、基础概念 Java BigDecimal 是一个用于高精度计算的类。普通的 double 或 float 类型只能精确表示有限的数字,而对于需要高精度计算的场景,BigDeci…

    编程 2025-04-25

发表回复

登录后才能评论