|
![]() |
名片设计 CorelDRAW Illustrator AuotoCAD Painter 其他软件 Photoshop Fireworks Flash |
|
java.sql包中的 java.sql.Driver, jdbc.sql.Connection等提供应程序开发人员统一的开发接口 数据库提供商提供相应的实现,对程序开发人员来讲只要知道这些接口都有哪些方式就可以了 但我们可以深入一些 看看到底这里面都做了那些事, 同时也可以学习其中的编程模式(如Interface模式等) 1 Class.forName(String classname) 的源码为: public final class Class implements java.io.Serializable { ... public static Class forName(String className) throws ClassNotFoundException { return forName0(className, true, ClassLoader.getCallerClassLoader()); } ... } 关于forName0 请自己查看jdk source. 目的是把指定的Class装载到JVM中来。(注重class的装载、初始化过程) 在装载过程中将执行被装载类的static块(如下) 2 sun的JdbcOdbcDriver 源码: public class JdbcOdbcDriver extends JdbcOdbcObject implements JdbcOdbcDriverInterface { ... /** * connect to DB */ public synchronized Connection connect(String s, Properties properties) throws SQLException { if(JdbcOdbcObject.isTracing()) JdbcOdbcObject.trace("*Driver.connect (" + s + ")"); if(!acceptsURL(s)) return null; if(hDbc != 0) { disconnect(hDbc); closeConnection(hDbc); hDbc = 0; } if(!initialize()) { return null; } else { JdbcOdbcConnection jdbcodbcconnection = new JdbcOdbcConnection(OdbcApi, hEnv, this); jdbcodbcconnection.initialize(getSubName(s), properties, DriverManager.getLoginTimeout()); jdbcodbcconnection.setURL(s); return jdbcodbcconnection; } } static { if(JdbcOdbcObject.isTracing()) JdbcOdbcObject.trace("JdbcOdbcDriver class loaded"); JdbcOdbcDriver jdbcodbcdriver = new JdbcOdbcDriver(); try { DriverManager.registerDriver(jdbcodbcdriver); } catch(SQLException sqlexception) { if(JdbcOdbcObject.isTracing()) JdbcOdbcObject.trace("Unable to register driver"); } } } public interface JdbcOdbcDriverInterface extends Driver { ... } 3 连接过程 jdbc.sql.Connection con = DriverManager.getConnection("jdbc:odbc:pubs","sa",""); public class DriverManager { public static synchronized Connection getConnection(String url, String user, String password) throws SQLException { java.util.Properties info = new java.util.Properties(); // Gets the classloader of the code that called this method, may // be null. ClassLoader callerCL = DriverManager.getCallerClassLoader(); if (user != null) { info.put("user", user); } if (password != null) { info.put("password", password); } return (getConnection(url, info, callerCL)); } private static synchronized Connection getConnection( String url, java.util.Properties info, ClassLoader callerCL) throws SQLException { ... Connection result = di.driver.connect(url, info); ... } } 返回类别: 教程 上一教程: JAVA何以保网络安全 下一教程: JAVA 语法介绍(二):运算符 您可以阅读与"JDBC到底是怎么连上数据库的"相关的教程: · jsp用jdbc连接db2数据库的方式 · 各种数据库的JDBC连接代码 · 通过JDBC连接ORACLE数据库的十大技巧 · JDBC连SYBASE数据库的几种方式 · 用连接池提高SERVLET访问数据库的效率 |
![]() ![]() |
快精灵印艺坊 版权所有 |
首页![]() ![]() ![]() ![]() ![]() ![]() ![]() |