1、 浅谈JDBC工作原理 目录JDBC应用背景JDBC概述JDBC工作原理通过JDBC实现对数据库访问JDBCJDBC应用背景应用背景JDBC应用背景 在Internet的热潮席卷之下,原本在单机或局域网中使用的数据库逐步移植至Internet中,Web技术与数据库管理系统(DBMS)相互融合成为必然趋势,数据库厂家和Web公司纷纷推出各自的产品和中间件支持Web技术和DBMS的融合,随着Web应用领域的不断扩展、信息量的不断增加,静态的Web页面越来越不能满足人们对Web信息服务的动态性、实时性和交互性的要求。为了进行网络上数据的高效存取,实现交互式动态Web页面,就必须以大量数据资源为基础,
2、因此必然要在Web中引入数据库。Web数据库是指将数据库技术与Web技术融合,使数据库成为Web的重要组成部分的数据库。JDBC应用背景 B/S结构将数据处理过程分为表示层、功能层和数据层三部分,分别由Web浏览器、具有应用程序扩展功能的Web服务器和数据库服务器实现。JDBC应用背景 客户机和服务器或者服务器和服务器之间传送数据,实现客户机群和服务器群之间的通信。中间件在整个分布式系统中起数据总线的作用各种异构系统通过中间件有机地结合成一个整体。在客户机里的应用程序需要网络上某个服务器中的数据或服务时,应用程序需访问中间件,中间件将查找数据源或服务,并在发送应用程序请求后重新打包响应,将其传
3、回应用程序。JDBCJDBC技术概述技术概述JDBC技术概述JDBC概述JDBC设计目的JDBC概述JDBC与ODBC对比JDBCJDBC工作原理工作原理JDBC工作原理JDBC工作原理JDBC主要功能创建与数据库的连接;发送SQL语句到任何关系型数据库中;处理数据并查询结果。创建与数据库的连接创建与数据库的连接1.应用必要的包应用必要的包 import java.sql.*;/它包含有操作数据库的各个类的接口2.加载连接数据库的驱动程序类加载连接数据库的驱动程序类 为实现与特定的数据库相连接,JDBC必须加载相应的驱动程序类。这通常可以采用Class.forName()方法显示地加载一个驱动
4、程序类,由驱动程序负责向DriverManager登记注册并在与数据库相连接时,DriverManager将使用此驱动程序。Class.forName(“sun.jdbc.odbc.JdbcDriver”);/例如:mysql的驱动程序连接:”com.mysql.jdbc.Driver”sqlServer的驱动程序连接:com.microsoft.jdbc.sqlserver.SQLServerDriver“Oracle的驱动程序连接:oracle.jdbc.driver.OracleDriver注意:这条语句直接加载了sun公司提供的JDBC-ODBC Bridge驱动程序类。3.创建与数据
5、源的连接创建与数据源的连接 (1)数据源的URL:jdbc:database locator其中:jdbc-指出要使用的JDBC subprotocal-定义驱动程序类型 database locator-提供网络数据库的位置和端口号(包括主机名,端口和数据库名等)如:jdbc:odbc:/:port/Dbfile Oracle-“jdbc:oracle:thin:localhost:1521:数据库名;sqlServer-jdbc:microsoft:sqlserver:/机器名:1433;DataBaseName=数据库名;mysql-=“jdbc:mysql:/localhost:330
6、6/数据库名”;JDBC 工作原理 Java程序连接到不同数据库程序连接到不同数据库public interface connenctionParam public void DBManager();public Connection getConnection(String userName,String psw,String dbName);public class SqlServerParam implements connenctionParam public void DBManager()try Class.forName(com.microsoft.jdbc.sqlserver.
7、SQLServerDriver“);catch(ClassNotFoundException e)e.printStackTrace();public Connection getConnection(String userName,String psw,String dbName)String url=jdbc:microsoft:sqlserver:/机器名:1433;DataBaseName=“+dbName;try conn=DriverManager.getConnection(url,userName,psw);catch(SQLException e)e.printStackTr
8、ace();return conn;public class OrcaleParam implements connenctionParam public void DBManager()try Class.forName(oracle.jdbc.driver.OracleDriver);catch(ClassNotFoundException e)e.printStackTrace();public Connection getConnection(String userName,String psw,String dbName)String url=“jdbc:oracle:thin:lo
9、calhost:1521:+dbName;try conn=DriverManager.getConnection(url,userName,psw);catch(SQLException e)e.printStackTrace();return conn;public class MySqlParam implements connenctionParam public void DBManager()try Class.forName(”com.mysql.jdbc.Driver”);catch(ClassNotFoundException e)e.printStackTrace();pu
10、blic Connection getConnection(String userName,String psw,String dbName)String url=“jdbc:mysql:/localhost:3306/”+dbName;try conn=DriverManager.getConnection(url,userName,psw);catch(SQLException e)e.printStackTrace();return conn;发送发送SQL语句到任何关系型数据库中语句到任何关系型数据库中1.创建创建Statement对象:对象:要想执行一个SQL查询语句,必须首先创建出
11、Statement对象,它封装代表要执行的sql语句,并执行SQL语句以返回一个ResultSet对象,这可以通过Connection类中的creatStatement()方法来实现。如:Statement stmt=conn.creatStatement();2.执行一个执行一个SQL查询语句,以查询数据库中的数据;查询语句,以查询数据库中的数据;(1)方法executQuery:用于产生单个查询结果集语句,例如SELECT语句等。ResultSet rs=stmt.executQuery(”select*from stu”);(2)方法executeUpdate:用于执行INSERT,UP
12、DATE,DELETE语句以及sql DDL语句,例如CREATE TABLE 和DROP TABLE。executeUpdate的返回值时一个正整数,指示受影响行数。int k=stmt.executeUpdate(“INSERT INTO stu(id,name,age)value(null,张三,15)”);int n=stmt.executeUpdate(“update stu set name=孙林,age=20 where id=6”);int m=stmt.executUpdate(“delete from stu where id=6”);int p=stmt.executUpadte(“CREATE TABLE test1(id int,name varchar)”);stmt.executUpadte(“DROP TABLE test1”);stmt.executUpadte(“Alter Table stu add Column Adress VarChar(50)”);JDBC工作原理