java中用什么关闭jdbc?在JAVA中,常用的两种jdbc的驱动方式是什么
其实java中用什么关闭jdbc的问题并不复杂,但是又很多的朋友都不太了解在JAVA中,常用的两种jdbc的驱动方式是什么,因此呢,今天小编就来为大家分享java中用什么关闭jdbc的一些知识,希望可以帮助到大家,下面我们一起来看看这个问题的分析吧!
在JAVA中,常用的两种jdbc的驱动方式是什么
有两种常见的JDBC驱动方式:
1、JDBC-ODBC桥连优点:配置简单,只要配置一次就可以访问所有ODBC可以访问的数据库,这种方式适合个人的开发与测试
缺点:性能欠佳,不适合在实际系统中使用
2、纯Java驱动方式优点:跨平台,运行速度快
缺点:连接不同的数据库需要下载不同的JDBC驱动包
这种方式直接与数据库进行连接,适合开发大型项目
具体的可以上网查一下
java中使用JDBC完成数据库操作的基本步骤是什么
创建一个以JDBC连接数据库的程序,包含7个步骤: \x0d\x0a 1、加载JDBC驱动程序: \x0d\x0a在连接数据库之前,首先要加载想要连接的数据库的驱动到JVM(Java虚拟机), \x0d\x0a这通过java.lang.Class类的静态方法forName(String className)实现。 \x0d\x0a例如: \x0d\x0a try{ \x0d\x0a//加载MySql的驱动类 \x0d\x0a Class.forName("com.mysql.jdbc.Driver"); \x0d\x0a}catch(ClassNotFoundException e){ \x0d\x0a System.out.println("找不到驱动程序类,加载驱动失败!"); \x0d\x0a e.printStackTrace(); \x0d\x0a} \x0d\x0a成功加载后,会将Driver类的实例注册到DriverManager类中。 \x0d\x0a 2、提供JDBC连接的URL \x0d\x0a•连接URL定义了连接数据库时的协议、子协议、数据源标识。 \x0d\x0a•书写形式:协议:子协议:数据源标识 \x0d\x0a协议:在JDBC中总是以jdbc开始 \x0d\x0a子协议:是桥连接的驱动程序或是数据库管理系统名称。 \x0d\x0a数据源标识:标记找到数据库来源的地址与连接端口。 \x0d\x0a例如:(MySql的连接URL) \x0d\x0a jdbc:mysql: \x0d\x0a//localhost:3306/test?useUnicode=true&characterEncoding=gbk; \x0d\x0a useUnicode=true:表示使用Unicode字符集。如果characterEncoding设置为 \x0d\x0a gb2312或GBK,本参数必须设置为true。characterEncoding=gbk:字符编码方式。 \x0d\x0a 3、创建数据库的连接 \x0d\x0a•要连接数据库,需要向java.sql.DriverManager请求并获得Connection对象, \x0d\x0a该对象就代表一个数据库的连接。 \x0d\x0a•使用DriverManager的getConnectin(String url, String username, \x0d\x0a String password)方法传入指定的欲连接的数据库的路径、数据库的用户名和 \x0d\x0a密码来获得。 \x0d\x0a例如: \x0d\x0a//连接MySql数据库,用户名和密码都是root \x0d\x0a String url="jdbc:mysql://localhost:3306/test"; \x0d\x0a String username="root"; \x0d\x0a String password="root"; \x0d\x0a try{ \x0d\x0a Connection con= \x0d\x0a DriverManager.getConnection(url, username, password); \x0d\x0a}catch(SQLException se){ \x0d\x0a System.out.println("数据库连接失败!"); \x0d\x0a se.printStackTrace(); \x0d\x0a} \x0d\x0a 4、创建一个Statement \x0d\x0a•要执行SQL语句,必须获得java.sql.Statement实例,Statement实例分为以下3 \x0d\x0a种类型: \x0d\x0a 1、执行静态SQL语句。通常通过Statement实例实现。 \x0d\x0a 2、执行动态SQL语句。通常通过PreparedStatement实例实现。 \x0d\x0a 3、执行数据库存储过程。通常通过CallableStatement实例实现。 \x0d\x0a具体的实现方式: \x0d\x0a Statement stmt= con.createStatement(); \x0d\x0a PreparedStatement pstmt= con.prepareStatement(sql); \x0d\x0a CallableStatement cstmt= \x0d\x0a con.prepareCall("{CALL demoSp(?,?)}"); \x0d\x0a 5、执行SQL语句 \x0d\x0a Statement接口提供了三种执行SQL语句的方法:executeQuery、executeUpdate \x0d\x0a和execute \x0d\x0a 1、ResultSet executeQuery(String sqlString):执行查询数据库的SQL语句 \x0d\x0a,返回一个结果集(ResultSet)对象。 \x0d\x0a 2、int executeUpdate(String sqlString):用于执行INSERT、UPDATE或 \x0d\x0a DELETE语句以及SQL DDL语句,如:CREATE TABLE和DROP TABLE等 \x0d\x0a 3、execute(sqlString):用于执行返回多个结果集、多个更新计数或二者组合的 \x0d\x0a语句。 \x0d\x0a具体实现的代码: \x0d\x0a ResultSet rs= stmt.executeQuery("SELECT* FROM..."); \x0d\x0a int rows= stmt.executeUpdate("INSERT INTO..."); \x0d\x0a boolean flag= stmt.execute(String sql); \x0d\x0a 6、处理结果 \x0d\x0a两种情况: \x0d\x0a 1、执行更新返回的是本次操作影响到的记录数。 \x0d\x0a 2、执行查询返回的结果是一个ResultSet对象。 \x0d\x0a• ResultSet包含符合SQL语句中条件的所有行,并且它通过一套get方法提供了对这些 \x0d\x0a行中数据的访问。 \x0d\x0a•使用结果集(ResultSet)对象的访问方法获取数据: \x0d\x0a while(rs.next()){ \x0d\x0a String name= rs.getString("name"); \x0d\x0a String pass= rs.getString(1);//此方法比较高效 \x0d\x0a} \x0d\x0a(列是从左到右编号的,并且从列1开始) \x0d\x0a 7、关闭JDBC对象 \x0d\x0a操作完成以后要把所有使用的JDBC对象全都关闭,以释放JDBC资源,关闭顺序和声 \x0d\x0a明顺序相反: \x0d\x0a 1、关闭记录集 \x0d\x0a 2、关闭声明 \x0d\x0a 3、关闭连接对象 \x0d\x0a if(rs!= null){//关闭记录集 \x0d\x0a try{ \x0d\x0a rs.close(); \x0d\x0a}catch(SQLException e){ \x0d\x0a e.printStackTrace(); \x0d\x0a} \x0d\x0a} \x0d\x0a if(stmt!= null){//关闭声明 \x0d\x0a try{ \x0d\x0a stmt.close(); \x0d\x0a}catch(SQLException e){ \x0d\x0a e.printStackTrace(); \x0d\x0a} \x0d\x0a} \x0d\x0a if(conn!= null){//关闭连接对象 \x0d\x0a try{ \x0d\x0a conn.close(); \x0d\x0a}catch(SQLException e){ \x0d\x0a e.printStackTrace(); \x0d\x0a} \x0d\x0a}
java中连接数据库的方式,有JDBC还有什么
这是老师发给我们的资料,共享给你:
Type 1: jdbc-odbc桥
Jdbc-odbc桥是sun公司提供的,是jdk提供的的标准api.这种类型的驱动实际是把所有 jdbc的调用传递给odbc,再由odbc调用本地数据库驱动代码.(本地数据库驱动代码是指由数据库厂商提供的数据库操作二进制代码库,例如在oracle for windows中就是oci dll文件)
jdbc-odbc桥|odbc|厂商DB代码---数据库Server
只要本地机装有相关的odbc驱动那么采用jdbc-odbc桥几乎可以访问所有的数据库,jdbc- odbc方法对于客户端已经具备odbc driver的应用还是可行的.
但是,由于jdbc-odbc先调用 odbc再由odbc去调用本地数据库接口访问数据库.所以,执行效率比较低,对于那些大数据量存取的应用是不适合的.而且,这种方法要求客户端必须安装odbc驱动,所以对于基于 internet,intranet的应用也是不合适的.因为,你不可能要求所有客户都能找到odbc driver.
=====一般ACCESS用到的比较多,初学者用。实际项目是不用的。
Type 2:本地Api驱动
本地api驱动直接把jdbc调用转变为数据库的标准调用再去访问数据库.
这种方法需要本地数据库驱动代码.本地api驱动|厂商DB代码---数据库Server这种驱动比起jdbc-odbc桥执行效率大大提高了.但是,它仍然需要在客户端加载数据库厂商提供的代码库.这样就不适合基于internet的应用.并且,他的执行效率比起3,4型的jdbc驱动还是不够高.
Type3:网络协议驱动这种驱动实际上是根据我们熟悉的三层结构建立的. jdbc先把对数局库的访问请求传递给网络上的中间件服务器.中间件服务器再把请求翻译为符合数据库规范的调用,再把这种调用传给数据库服务器.如果中间件服务器也是用java开法的,那么在在中间层也可以使用1,2型 jdbc驱动程序作为访问数据库的方法.网络协议驱动--中间件服务器---数据库Server
由于这种驱动是基于server的.所以,它不需要在客户端加载数据库厂商提供的代码库.而且他在执行效率和可升级性方面是比较好的.因为大部分功能实现都在server端,所以这种驱动可以设计的很小,可以非常快速的加载到内存中.但是,这种驱动在中间件层仍然需要有配置其它数据库驱动程序,并且由于多了一个中间层传递数据,它的执行效率还不是最好.
Type4纯JAVA驱动
这种驱动直接把jdbc调用转换为符合相关数据库系统规范的请求.由于4型驱动写的应用可以直接和数据库服务器通讯.这种类型的驱动完全由java实现,因此实现了平台独立性.本地协议驱动---------数据库Server
由于这种驱动不需要先把jdbc的调用传给odbc或本地数据库接口或者是中间层服务器.所以它的执行效率是非常高的.而且,它根本不需要在客户端或服务器端装载任何的软件或驱动.这种驱动程序可以动态的被下载.但是对于不同的数据库需要下载不同的驱动程序.
以上对四种类型的jdbc驱动做了一个说明.那么它们适合那种类型的应用开发呢?
Jdbc-odbc桥由于它的执行效率不高,更适合做为开发应用时的一种过度方案,或着对于初学者了解jdbc编程也较适用.对于那些需要大数据量操作的应用程序则应该考虑2,3,4型驱动.在intranet方面的应用可以考虑2型驱动,但是由于3,4型驱动在执行效率上比2型驱动有着明显的优势,而且目前开发的趋势是使用纯java.所以3,4型驱动也可以作为考虑对象.至于基于internet方面的应用就只有考虑3,4型驱动了.因为3型驱动可以把多种数据库驱动都配置在中间层服务器.所以3型驱动最适合那种需要同时连接多个不同种类的数据库,并且对并发连接要求高的应用. 4型驱动则适合那些连接单一数据库的工作组应用。
现在是纯java开发,所以一般都用type4的jdbc driver。
END,本文到此结束,如果可以帮助到大家,还望关注本站哦!