java两个数据库连表查询语句_Java如何连接多个表并查询表中的数据内容?

在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

¥ 我要打赏 纠错/补充 收藏

你可能感兴趣的:(java两个数据库连表查询语句)