TA的每日心情 | 开心 2021-3-12 23:18 |
---|
签到天数: 2 天 [LV.1]初来乍到
|
JDBC(java Database Connection)从字面上看就知道是Java应用与数据库之间的通信。 谈到JDBC不得不考虑的几个重要的问题
1. Java访问数据库的时候,由于数据库可能由不同的厂商所提供,底层的通信机制可能是不相同的,在这种情况下,Java语言怎样保证与各种数据库通信呢? 2. Java能够连接到各种数据库后,怎样去访问呢? Java连接到数据库可以通过下面三种方法: 1. 通过JDBC-ODBC桥接驱动器:是微软公司提出的一种解决方案,微软公司在Windows系统里面就编写了一个模块,名叫ODBC,开放数据库连接,然后所有安装到Windows系统上的数据库只要支持ODBC(基本所有数据库都支持),通过ODBC就能够连接到数据库,所以只要Java语言与ODBC通信就行了,不需要知道是什么厂商的数据库。
2.通过数据库厂商提供的JDBC驱动:通常数据库不但要求在Windows平台上面运行,还要在Unix、Linux等平台上面运行,这中情况就不能使用ODBC,所以数据库厂商自己提供一个数据库驱动,让Java来注册驱动,连接到各种数据库,所以支持跨平台。如果需要修改不同厂商的数据库,这时就需要修改注册驱动和获得连接的代码,这也是这种方法的存在缺点。 3. 通过在服务器上面建立连接池、数据源:通过JNDI技术寻找服务器上的数据源,进而通过连接池连接到数据库。连接池支持所有的数据库,如果需要修改不同厂商数据库,只需要在服务器的控制台上修改相关信息,并不需要修改代码。通常服务器是跨平台的。所以这种方法通常是连接数据库最好的方法。 通过JDBC-ODBC桥接驱动器连接数据库 建立ODBC数据源:在控制面板->管理工具->数据源->系统DSN->添加各种数据库的数据源。 案例:查询员工表里面的全部资料,在控制台上打印。 编写QueryEmployees类,实现ODBC数据源的方式查找所有员工的信息,代码如下
package wang.jdbc;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
public class QueryEmployees {
public static void main(String[] args) {
Connection conn = null;
try {
// 指定驱动,连接到ODBC
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
// 获取连接
conn = DriverManager.getConnection("jdbc:odbc:XEDS", "hr", "hr");
// 运行sql语句
Statement stat = conn.createStatement();
String sql = "select * from employees";
// 获得结果
ResultSet rs = stat.executeQuery(sql);
// 显示结果
while(rs.next()) {
String id = rs.getString("EMPLOYEE_ID");
String name = rs.getString("FIRST_NAME") + " " + rs.getString("LAST_NAME");
String email = rs.getString("EMAIL");
System.out.println(id + " " + name + " " + email);
}
} catch (Exception e) {
e.printStackTrace();
} finally {
try {
if(conn != null) {
conn.close();
conn = null;
}
} catch (SQLException e) {
e.printStackTrace();
}
}
}
}
新增、删除、修改等操作略之。 调用存储过程 调用存储过程,分以下三种情况: 1. 调用不带参数的存储过程 2. 调用带参数的存储过程 3. 调用带输出参数的存储过程 编写CallPrc类,实现这三种情况下调用存储过程,代码如下
package wang.jdbc;
import java.sql.CallableStatement;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Types;
public class CallPrc1 {
public static void main(String[] args) {
Connection conn = null;
try {
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
conn = DriverManager.getConnection("jdbc:odbc:XEDS", "hr", "hr");
//调用不带参数的存储过程,prc1是一个不带参数的存储过程
CallableStatement cs1 = conn.prepareCall("{call prc1 ()}");
cs1.execute();
//调用带参数的存储过程,prc2(String, double)是一个带参数的存储过程
CallableStatement cs2 = conn.prepareCall("{call prc2 (?,?)}");
cs2.setString(1, "参数1");
cs2.setDouble(2, 45.0);
cs2.execute();
//调用带输出参数的存储过程,prc3(String, String, String(output参数))是一个带输出参数的存储过程
CallableStatement cs3 = conn.prepareCall("{call prc3 (?,?)}");
cs3.setString(1, "参数1");
cs3.setString(2, "参数2");
cs3.registerOutParameter(3, Types.CHAR);
cs3.execute();
String str = cs3.getString(3);//得到输出参数的值
} catch (Exception e) {
e.printStackTrace();
} finally {
try {
if(conn != null) {
conn.close();
conn = null;
}
} catch (SQLException e) {
e.printStackTrace();
}
}
}
}
事务 案例:转账的时候,我的钱减少了,他的钱增加了,实现时希望这两个过程要么全部运行,要么全部不运行,这种情况就可以把这两个修改操作做成一个事务。 编写Transaction类,实现以上转账功能,代码如下
package wang.jdbc;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;
public class Transaction {
public static void main(String[] args) {
Connection conn = null;//默认事务自动提交
try {
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
conn = DriverManager.getConnection("jdbc:odbc:XEDS", "hr", "hr");
Statement stat = conn.createStatement();
conn.setAutoCommit(false);//修改为不要自动提交事务
// sql1和sql2要么全部运行,要么全部不要运行,把以下两句定义成事务
String sql1 = "update ....";
String sql2 = "update ....";
stat.executeUpdate(sql1);
stat.executeUpdate(sql2);
conn.commit();//提交以上操作,如果以上两步出现异常就回退
} catch (Exception e) {
try {
conn.rollback();
} catch (SQLException e1) {
e1.printStackTrace();
}
} finally {
try {
if(conn != null) {
conn.close();
conn = null;
}
} catch (SQLException e) {
e.printStackTrace();
}
}
}
}
通过数据库驱动程序连接数据库
案例:使用oracle驱动连接,查询所有员工信息。
编写OraDriver类,利用oracle驱动连接,查询所有的员工信息,代码如下
package wang.jdbc;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
public class OraDriver {
public static void main(String[] args) {
Connection conn = null;
try {
Class.forName("oracle.jdbc.driver.OracleDriver");//载入驱动
String url = "jdbc:oracle:thin:@localhost:1521:XE";
conn = DriverManager.getConnection(url, "hr" ,"hr");
Statement stat = conn.createStatement();
String sql = "select * from employees";
ResultSet rs = stat.executeQuery(sql);
while(rs.next()) {
String id = rs.getString("EMPLOYEE_ID");
String name = rs.getString("FIRST_NAME") + " " + rs.getString("LAST_NAME");
String email = rs.getString("EMAIL");
System.out.println(id + " " + name + " " + email);
}
} catch (Exception e) {
e.printStackTrace();
} finally {
try {
if(conn != null) {
conn.close();
conn = null;
}
} catch (SQLException e) {
e.printStackTrace();
}
}
}
}
通过Weblogic建立连接池、数据源连接数据库
Weblogic有一种能力,能够把很多数据库连接放到连接池里面,然后这些连接以数据源的形式对外发布,供外部访问,实现的具体步骤如下
1. 建立连接池(具体步骤略之);
2. 建立数据源(具体步骤略之),通过JNDI对外发布。
编写Pool类,实现weblogic的连接池和数据源技术来连接数据库,代码如下
package wang.jdbc;
import java.sql.*;
import javax.naming.Context;
import javax.naming.InitialContext;
import javax.sql.DataSource;
import java.util.Hashtable;
public class Pool {
public static void main(String[] args) {
//连接到weblogic,查找数据源获得数据库连接
Hashtable table = new Hashtable();
//table里面放置连接基本信息
table.put(Context.INITIAL_CONTEXT_FACTORY, "weblogic.jndi.WLInitialContextFactory");
table.put(Context.PROVIDER_URL, "t3://localhost:7001");
table.put(Context.SECURITY_PRINCIPAL, "weblogic");
table.put(Context.SECURITY_CREDENTIALS, "weblogic");
//查询服务器中的数据源
try {
Context context = new InitialContext(table);
Object obj = context.lookup("DS1");
DataSource ds = (DataSource)obj;
Connection conn = ds.getConnection();
Statement stat = conn.createStatement();
String sql = "select * from employees";
ResultSet rs = stat.executeQuery(sql);
while(rs.next()) {
String id = rs.getString("EMPLOYEE_ID");
String name = rs.getString("FIRST_NAME") + " " + rs.getString("LAST_NAME");
String email = rs.getString("EMAIL");
System.out.println(id + " " + name + " " + email);
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
|
|