Java通过JDBC访问数据库(两种方式)

Java通过JDBC访问数据库(两种方式)

    利用java语言访问数据库时可以采用JDBC,那么什么是JDBC呢?JDBC(Java Data Base Connectivity,java数据库连接)是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问,它由一组用Java语言编写的类和接口组成。也就是说,能够通过JDBC提供的类和接口进行对数据库的访问。
    在具体访问数据库的时候,JDBC提供了两种方式:JDBC-ODBC桥接器方式和加载纯java数据库驱动程序。这两种方式只是在连接数据库的时候有一些差异,之后的对数据库操作的逻辑代码没有什么区别。下面就分别介绍这两种方式,同时最后会给出实现的代码。

一、JDBC-ODBC桥接器方式

    这种方式是通过JDBC访问ODBC,ODBC再访问数据库来实现的,ODBC是什么呢?开放数据库连接(Open Database Connectivity,ODBC)是微软公司开放服务结构(WOSA,Windows Open Services Architecture)中有关数据库的一个组成部分,它建立了一组规范,并提供了一组对数据库访问的标准API(应用程序编程接口)。也就是由微软开发的访问数据库的API接口。通过这种方式进行配置的时候,首先需要配置好ODBC,我机器上测试的是MySQL,需要安装MySQL的ODBC驱动下载地址
    安装好驱动后,需要配置ODBC。

之后,就可以通过代码访问数据库了。具体的代码会附在最后。

二、纯java数据驱动程序
需要下载MySQL的纯java驱动程序包,可以在这里下载地址进行下载。
然后需要把其中的jar包引用到自己工程的编译目录中。

这样就可以了,下面是对应两种方式访问数据库的java代码。
import java.sql.Connection;
import java.sql.DatabaseMetaData;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import com.mysql.jdbc.Driver;

public class Exmaple {

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		System.out.println("JDBC-ODBC桥接器方式连接数据库");
		Connection con;
		Statement sql;
		ResultSet rs;

		try {
			Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
		} catch (ClassNotFoundException e) {
			e.printStackTrace();
		}
		try {
			con = DriverManager.getConnection("jdbc:odbc:mysqltest", "", "");
			sql = con.createStatement();
			rs = sql.executeQuery("select * from person");
			while (rs.next()) {
				System.out.println(rs.getString(1) + "\t" + rs.getString(2)
						+ "\t" + rs.getString(3) + "\t" + rs.getString(4));
			}
			System.out.println("返回表的所有列:");
			DatabaseMetaData metadata = con.getMetaData();
			ResultSet rs2 = metadata.getColumns(null, null, "person", null);
			while (rs2.next()) {
				System.out.println(rs2.getString(4));
			}

		} catch (SQLException e) {
			e.printStackTrace();
		}

		System.out.println("JDBC-ODBC桥接器方式连接数据库成功!\n\n\n\n");

		System.out.println("纯java方式连接数据库");
		Connection con2;
		Statement sql2;
		ResultSet rs3;
		try {
			Class.forName("com.mysql.jdbc.Driver");
		} catch (ClassNotFoundException e) {
			e.printStackTrace();
		}
		try {
			con2 = DriverManager.getConnection("jdbc:mysql://localhost/test",
					"用户名", "密码");
			sql2 = con2.createStatement();
			rs3 = sql2.executeQuery("select * from person");
			while (rs3.next()) {
				System.out.println(rs3.getString(1) + "\t" + rs3.getString(2)
						+ "\t" + rs3.getString(3) + "\t" + rs3.getString(4));
			}
			System.out.println("返回表的所有列:");
			DatabaseMetaData metadata2 = con2.getMetaData();
			ResultSet rs4 = metadata2.getColumns(null, null, "person", null);
			while (rs4.next()) {
				System.out.println(rs4.getString(4));
			}

		} catch (SQLException e) {
			e.printStackTrace();
		}
		System.out.println("纯java方式连接数据库测试成功!");
	}

}
运行结果就是把整个表中的内容进行了简单的遍历操作。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值