大家应该都知道,通过JDBC访问数据库,有四种不同的方式:
- JDBC-ODBC桥
- 本地API驱动
- 网络协议驱动
- 本地协议驱动
1.JDBC-ODBC桥
这种方式把对JDBC API的调用映射成对ODBC API的调用,典型的Adapter,借助现成的ODBC驱动程序,能够驱动一切提供ODBC访问方式的数据库。
它的调用结构如下:

优点:
能访问一切提供了ODBC驱动程序的数据库。
缺点:
性能低下。
需要在每一台客户机上安装ODBC驱动程序,因而丧失了Java跨平台的特性。
不适合大型程序。
2.本地API驱动
这种方式把对JDBC API的调用映射成对数据库客户端本地API的调用。
它的调用结构图如下:

优点:
性能比JDBC—ODBC桥方式要好。
缺点:
需要为每台客户机加载数据库本地API的协议文件(如Oracle SQLnet)
不能用在Internet上
3.网络协议驱动
通过使用中间件平台,让对JDBC API的调用在网络间传输,再由中间件平台的Server端把调用转化为数据库对应的通讯协议。
它的结构图如下:

优点:
不需要在客户端安装额外的数据库供应商相关的文件,可移植性好。
部署方便,具有良好的可伸缩性。
适用于使用多种数据库的Internent应用。
缺点:
使用了中间件平台,效率有所降低。
4.本地协议驱动
如果使用MySQL的话,这种方式应该是我们平常使用最多的方式了,它直接把对JDBC API的调用转化成数据库服务器使用的网络协议,通常需要一个驱动程序(比如MySQL的ConnectorJ)
它的调用结构如下:

优点:
完全符合Java的跨平台要求。
效率比使用“网络协议驱动”的方式要高。
适用于使用单一数据库的Internet应用。
缺点:
需要数据库供应商提供驱动程序,否则无法使用本方法。
本文深入探讨了JDBC访问数据库的四种方法:JDBC-ODBC桥、本地API驱动、网络协议驱动和本地协议驱动,分析了各自的优缺点,帮助读者理解不同连接方式的适用场景。
7040

被折叠的 条评论
为什么被折叠?



