java中连接数据库的方式,有JDBC还有什么?

java中连接数据库的方式,有JDBC还有什么?,第1张

这是老师发给我们的资料,共享给你:\x0d\x0aType 1: jdbc-odbc桥 \x0d\x0aJdbc-odbc 桥 是sun公司提供的,是jdk提供的的标准api. 这种类型的驱动实际是把所有 jdbc的调用传递给odbc ,再由odbc调用本地数据库驱动代码.( 本地数据库驱动代码是指 由数据库厂商提供的数据库 *** 作二进制代码库,例如在oracle for windows中就是oci dll 文 件) \x0d\x0a\x0d\x0ajdbc-odbc桥|odbc|厂商DB代码---数据库Server\x0d\x0a\x0d\x0a只要本地机装有相关的odbc驱动那么采用jdbc-odbc桥几乎可以访问所有的数据库,jdbc- odbc方法对于客户端已经具备odbc driver的应用还是可行的.\x0d\x0a\x0d\x0a但是,由于jdbc-odbc先调用 odbc再由odbc去调用本地数据库接口访问数据库.所以,执行效率比较低,对于那些大数据量 存取的应用是不适合的.而且,这种方法要求客户端必须安装odbc 驱动,所以对于基于 internet ,intranet的应用也是不合适的.因为,你不可能要求所有客户都能找到odbc driver. \x0d\x0a\x0d\x0a=====一般ACCESS用到的比较多,初学者用。实际项目是不用的。\x0d\x0a\x0d\x0aType 2: 本地Api驱动 \x0d\x0a\x0d\x0a本地api驱动直接把jdbc调用转变为数据库的标准调用再去访问数据库.\x0d\x0a\x0d\x0a这种方法需要本地 数据库驱动代码. 本地api驱动|厂商DB代码---数据库Server这种驱动比起jdbc-odbc桥执行效率大大提高了.但是,它仍然需要在客户端加载数据库厂商 提供的代码库.这样就不适合基于internet的应用.并且,他的执行效率比起3,4型的jdbc驱动 还是不够高. \x0d\x0a\x0d\x0aType3:网络协议驱动 这种驱动实际上是根据我们熟悉的三层结构建立的. jdbc先把对数局库的访问请求传递给网 络上的中间件服务器. 中间件服务器再把请求翻译为符合数据库规范的调用,再把这种调用 传给数据库服务器.如果中间件服务器也是用java开法的,那么在在中间层也可以使用1,2型 jdbc驱动程序作为访问数据库的方法. 网络协议驱动--中间件服务器---数据库Server \x0d\x0a\x0d\x0a由于这种驱动是基于server的.所以,它不需要在客户端加载数据库厂商提供的代码库.而且 他在执行效率和可升级性方面是比较好的.因为大部分功能实现都在server端,所以这种驱动 可以设计的很小,可以非常快速的加载到内存中. 但是,这种驱动在中间件层仍然需要有配置 其它数据库驱动程序,并且由于多了一个中间层传递数据,它的执行效率还不是最好. \x0d\x0a\x0d\x0aType4 纯JAVA驱动 \x0d\x0a这种驱动直接把jdbc调用转换为符合相关数据库系统规范的请求.由于4型驱动写的应用可 以直接和数据库服务器通讯.这种类型的驱动完全由java实现,因此实现了平台独立性. 本地协议驱动---------数据库Server \x0d\x0a\x0d\x0a由于这种驱动不需要先把jdbc的调用传给odbc或本地数据库接口或者是中间层服务器.所 以它的执行效率是非常高的.而且,它根本不需要在客户端或服务器端装载任何的软件或驱动. 这种驱动程序可以动态的被下载.但是对于不同的数据库需要下载不同的驱动程序. \x0d\x0a\x0d\x0a以上对四种类型的jdbc驱动做了一个说明.那么它们适合那种类型的应用开发呢? \x0d\x0a\x0d\x0aJdbc-odbc桥由于它的执行效率不高,更适合做为开发应用时的一种过度方案,或着对于初学 者了解jdbc编程也较适用. 对于那些需要大数据量 *** 作的应用程序则应该考虑2,3,4型驱动.在intranet方面的应用可以 考虑2型驱动,但是由于3,4型驱动在执行效率上比2型驱动有着明显的优势,而且目前开发 的趋势是使用纯java.所以3,4型驱动也可以作为考虑对象. 至于基于internet方面的应用就只有考虑3,4型驱动了. 因为3型驱动可以把多种数据库驱 动都配置在中间层服务器.所以3型驱动最适合那种需要同时连接多个不同种类的数据库, 并且对并发连接要求高的应用. 4型驱动则适合那些连接单一数据库的工作组应用。\x0d\x0a\x0d\x0a现在是纯java 开发,所以一般都用type4的jdbc driver。

DbConnect

db

=

DbConnect.

getInstance

()

这是一个连接数据库的类(你自己写的),初始化

db相当一个别名,可以点出(.)该类里面的方法

Connection

conn

=

db.getConnect()

db.getConnect()这个方法

应该是你

写的一个连接方法了,返回的是Connection

类型,所以用他接收

此时已经连接的数据库了。接下来你要对数据库做什么····

String

sql="select

*from

(select

*from

notice_hanchao

order

by

insert_time

desc)"

一条sql查询语句

PreparedStatement

ps

=

conn.prepareStatement(sql)

conn.prepareStatement(sql)数据库对

sql语句

判断和执行,返回的是PreparedStatement

所以用他接收

ResultSet

rs

=

ps.executeQuery()

执行sql语句后要接收吧,ps.executeQuery()返回一个

结果集

,用ResultSet

去接收

接下来你可以打印了

rs.getString(1)

rs.get类型(1)

rs.getString(2)

rs.get类型(2)········

不懂就去问你们老师吧···我只能这么写了··希望能帮助你

JDBC是java数据库连接技术的简称,它提供了连接各种数据库的能力,这便使程序的可维护性和可扩展性大大的提高了.JDBC连接数据库常见的驱动方式有两种,一种是jdbc-odbc即桥连另外一种是纯java驱动.一般在做java开发的时候用第二种.so前一种我就不说了,纯java驱动方式连接步骤如下:

1.先把一个jdbc的jar包导入到项目(用MyEclipse开发)的lib中.

2.代码如下:

[c-sharp] view plain copy

import java.sql.*

/**

* 连接数据库帮助类

* @author Administrator

*

*/

public class BaseDao {

private static final String DRIVER="com.microsoft.sqlserver.jdbc.SQLServerDriver"

private static final String URL = "jdbc:sqlserver://localhost:1433DatabaseName=LibraryManageSystem"

private static final String USERNAME="sa"

private static final String PASSWORD="sa"

/**

* 连接数据库

* @return 数据库连接对象

* @throws ClassNotFoundException

* @throws SQLException

*/

public Connection getConn()throws ClassNotFoundException,SQLException{

Class.forName(DRIVER)

Connection conn = DriverManager.getConnection(URL,USERNAME,PASSWORD)

return conn

}

/**

* 释放资源

* @param conn

* @param pstmt

* @param rs

* @throws SQLException

*/

public void closeAll(Connection conn,PreparedStatement pstmt,ResultSet rs)throws SQLException{

if(rs!=null){

rs.close()

}

if(pstmt!=null){

pstmt.close()

}

if(conn!=null){

conn.close()

}

}

/**

* 执行SQL语句,可以进行增、删、改的 *** 作

* @param sql

* @return 影响条数

* @throws ClassNotFoundException

* @throws SQLException

*/

public int executeSQL(String sql)throws ClassNotFoundException,SQLException{

Connection conn = this.getConn()

PreparedStatement pstmt = conn.prepareStatement(sql)

int number = pstmt.executeUpdate()

this.closeAll(conn, pstmt, null)

return number

}

}

从代码知道首先吧jdbc驱动类装载java虚拟机中,即Class.forName(DRIVER)其次加载驱动并建立于数据库的连接Connection conn = DriverManager.getConnection(URL,USERNAME,PASSWORD)然后发送SQL语句并的到结果集.之后处理结果,最后要关闭数据库的连接,释放资源.当然我说的这样连接数据库的方式使用的软件是sql和MyEclipse.

使用配置文件来连接数据库,当然这样的连接需要进行一些配置.其实这样的连接用专业术语来说就是连接池,连接池是负责分配管理和释放数据库连接.它允许用用程序重复使用一个现有的数据库连接不再重复建立连接.释放空闲时间超过最大空闲时间的数据库连接以避免因为没有释放数据库而引起的数据库遗漏.

连接池的创建分为以下几个步骤:1.配置context.xml文件  这个文件是服务器(指tomcat)的一个conf文件夹中,拷贝出来放入项目的lib文件夹中,具体配置如下:

[c-sharp] view plain copy

<Resource name="jdbc/book" auth="Container" type="javax.sql.DataSource"

maxActive="100" maxIdle="20" maxWait="100" username="sa" password="sa"

driverClassName="com.microsoft.sqlserver.jdbc.SQLServerDriver"

url="jdbc:sqlserver://localhost:1433dataBaseName=book"

/>在config.xml文件中加入Resource标签,然后对数据库信息进行配置,当然这个数据库指的也是sqlserver有疑问可以qq757966892联系

之后把数据库的驱动包,这里指的是sql2005的包放入服务器的lib中,这样以后如果在你自己的机子上都不用在重新导入这个包了.

然后就是从MyEclipse中取得这样的连接从而对数据库进行一些 *** 作具体代码如下:

[c-sharp] view plain copy

package web.login.dao

import java.sql.Connection

import java.sql.PreparedStatement

import java.sql.ResultSet

import javax.naming.Context

import javax.naming.InitialContext

import javax.sql.DataSource

public class BaseDao {

protected Connection conn

protected PreparedStatement ps

protected ResultSet rs

protected String sql

public Connection getConn(){

try {

Context context=new InitialContext()

DataSource ds=(DataSource)context.lookup("java:comp/env/jdbc/user")

return ds.getConnection()

} catch (Exception e) {

e.printStackTrace()

return null

}

}

public void closeAll(Connection conn,PreparedStatement ps,ResultSet rs){

try {

if(rs!=null){

rs.close()

rs=null

}

if(ps!=null){

ps.close()

ps=null

}

if(conn!=null){

conn.close()

conn=null

}

} catch (Exception e) {

e.printStackTrace()

}

}

}

之后便可以建立业务类从而对数据库进行 *** 作.


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/9917911.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-03
下一篇2023-05-03

发表评论

登录后才能评论

评论列表(0条)

    保存