双表查询java代码_Java如何连接多个表并查询表中的数据内容?

本文展示了如何在Java编程中通过JDBC连接MySQL数据库,并使用INNER JOIN查询从两个表(employee和dept)中获取并显示数据。示例代码详细解释了连接数据库、执行SQL查询和处理结果集的过程,以展示员工的姓名、年龄及其所在的部门。
摘要由CSDN通过智能技术生成

在Java编程中,如何连接多个表并显示表中的数据内容?假定数据库名称是:testdb,其中有两张表:employee和dept,employee表中有4条记录,dept表中有2条记录。

创建数据库表的语句 -

use testdb;

-- 员工表

drop table if exists employees;

create table if not exists employees (

id int not null primary key,

age int not null,

name varchar(64),

dept_id int(10)

);

INSERT INTO employees VALUES (100, 28, 'MaxSu', 1);

INSERT INTO employees VALUES (101, 25, 'WeiWang', 2);

INSERT INTO employees VALUES (102, 30, 'KidaSu', 2);

INSERT INTO employees VALUES (103, 28, 'KobeBryant', 1);

----

-- 部门表

drop table if exists dept;

create table if not exists dept (

id int not null primary key,

name varchar (64)

);

INSERT INTO dept VALUES (1, '技术部');

INSERT INTO dept VALUES (2, '市场部');

以下示例使用inner join连接两个表中的数据。要显示两个表的数据内容,可使用resultSet的getString()方法。

package com.yiibai;

import java.sql.*;

public class RetrieveContentsFromMoreTable {

public static void main(String[] args) throws Exception {

String JDBC_DRIVER = "com.mysql.jdbc.Driver";

String DB_URL = "jdbc:mysql://localhost/testdb?useSSL=false";

String User = "root";

String Passwd = "123456";

try {

Class.forName(JDBC_DRIVER);

} catch (ClassNotFoundException e) {

System.out.println("Class not found " + e);

}

Connection con = DriverManager.getConnection(DB_URL, User, Passwd);

Statement stmt = con.createStatement();

String query = "SELECT e.name, e.age, d.name AS dname From employees e INNER JOIN dept d On e.dept_id = d.id";

ResultSet rs = stmt.executeQuery(query);

System.out.println("姓名 年龄 所在部门");

System.out.println("====================================");

while (rs.next()) {

String name = rs.getString("name");

String dname = rs.getString("dname");

int age = rs.getInt("age");

System.out.println(name + " " + age + " " + dname);

}

System.out.println();

}

}

上述代码示例将产生以下结果。

姓名 年龄 所在部门

====================================

MaxSu 28 技术部

WeiWang 25 市场部

KidaSu 30 市场部

KobeBryant 28 技术部

注:如果JDBC驱动程序安装不正确,将获得ClassNotfound异常。

Class not found java.lang.ClassNotFoundException: com.mysql.jdbc.Driver

JDBC Class found

SQL exception occuredjava.sql.SQLException: No suitable driver found for jdbc:mysql://localhost/testdb

¥ 我要打赏

纠错/补充

收藏

加QQ群啦,易百教程官方技术学习群

注意:建议每个人选自己的技术方向加群,同一个QQ最多限加 3 个群。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值