1.介绍
许多开发者和用户都在寻找Java程序中访问数据库的便捷方法。由于Java是一个健壮,安全,易于使用的,易于理解且可以从网络中自动download,所以它成为开发数据库应用的一种良好的语言基础。它提供了C,C,Smalltalk,BASIC,COBOL,and4GLs的许多优点。许多公司已经开始在Java与DBMS的连接方面做工作。
许多Java应用开发者都希望能够编写独立于特定DBMS的程序,而我们也相信一个独立于DBMS的接口将使得与各种各样DBMS连接变得最为便捷,开发更加迅速。所以我们认为定义一个通用的SQL数据库存取框架,在各种各样的提供数据库连接模块上提供统一的界面是十分有意义的。这使程序员可以面对单一的数据库界面,使数据库无关的Java工具和产品成为可能,使得数据库连接的开发者可以提供各种各样的连接方案。我们看到我们定义一个通用低层的,支持基本SQL功能的JavaDataBaseConnectivity(JDBC)API的紧迫任务。
幸运的是我们不必从头设计一个SQLAPI。我们可以把我们的工作建立在X/OpenSQLCLI(调用层接口)之上(它也是Microsoft'sODBC的基础)。
我们主要任务是定义一个自然的Java接口来与X/OpenCLI中定义的基本的抽象层和概念连接。
JDBCAPI得到数据库开发厂商,连接开发厂商,ISV,以及应用开发者的支持是十分重要的。我们相信把我们的工作建立在ODBC抽象层的基础上将JDBC更加容易得到大家的接受。而且从技术上来说,ODBC是我们设计工作的一个良好基础。
因为ODBC是一个C语言接口,所以ODBC在Java中直接使用不适当。从Java中来调用C代码在安全性,健壮性,实现的方便,可移植性等等方面有许多不便。它使得Java在这些方面的许多优点得不到发挥。
我们已经在短期里面实现了一个建立在ODBC上的API。长远来看,我们可以通过其他方式提供实现。
1.1.注意/r
我们非常感谢在数据库,数据库连接和数据库工具领域的许多早期的工作者。他们为JDBC的早期草案提供了很好的意见和建议。他们的工作对本规范起了不可估量的作用。
2.目标与哲学
这个部分描述了指引这个API开发的目标以及哲学。
2.1.SQL级API
我们的主要目标是为Java定义一个“调用级”(call-level)的SQL接口。着意味着我们主要的注意力集中在执行原原本本的SQL语句并且取回结果。我们预计高层的API也将被定义,这些可能将建立在基层的接口上。这些高层接口包括象直接地、透明地把表里面的数据影射到Java类里面,用语法树表示更加通用的查询,以及Java内嵌的SQL语法。
我们希望大量的应用开发工具将使用我们的API。然而我们也希望程序员能够使用我们的API,尤其是目前这样在Java里没有任何其他手段(应该是说数据库访问手段)的情况下。
2.2.遵循SQL
数据库系统支持各式各样的SQL语法和语义,它们相互之间在比较高级的功能例如外部连接,内嵌过程等方面并不一致,尽管我们能够盼望着随时间的推移这些部分的SQL可以获得标准化。同时我们采取这样的态度与立场:
Infact,anapplicationqueryneednotevenbeSQL,oritmaybeaspecializedderivativeofSQL,e.g.fordocumentorimagequeries,designedforspecificDBMSs.InordertopassJDBCcompliancetestsandtobecalled"JDBCCOMPLIANT?"werequirethatadriversupportatleastANSISQL-2EntryLevel.Thisgivesapplicationsthatwantwideportabilityaguaranteedleastcommondenominator.WebelieveANSISQL-2EntryLevelisreasonablypowerfulandisreasonablywidelysupportedtoday.
JDBC允许查询表达式直接传递到底层的数据驱动,这样一个程序可以获得尽量多的SQL功能,但是可能被DBMS拒绝。事实上,一个程序的查询甚至可以不是SQL的,或者是SQL的一个特殊演化,例如:为专门数据库设计的文本或者图形查询。
为了通过JDBC兼容的测试,并且能够被称为JDBC兼容,我们要求一个驱动至少支持ANSISQL-2的标准。这使得那些需要广泛移植性的程序获得一个最小的分母(这句话的原文是:
Thisgivesapplicationsthatwantwideportabilityaguaranteedleastcommondenominator.)。
我们相信ANSISQL-2是足够强大的,并且是得到足够支持的。
2.3.JDBC必须可以建立在现有的数据库接口上
我们必须能够保证JDBCSQLAPI能够建立在普通的SQLAPI上,尤其是ODBC。这些要求已经对这个规范的一些部分产生了影响,尤其是对传出参数(OUTparameter)和大数据块的处理。
2.4.必须保证这个接口与JAVA系统的其他部分保持一致
目前对JAVA的积极回应已经十分热烈。很大程度上是由于这个语言标准以及标准运行时库被认为是一致,简单和强大的。我们将尽我们所能,提供这个Java数据库接口,这个接口将建立在Java内核现有的这种风格,并且将进一步加强它。
2.5.保持简单
WewouldprefertokeepthisbaseAPIassimpleaspossible,atleast
initially.Ingeneralwewouldprefertoprovideasinglemechanismforperformingaparticulartask,andavoidprovid-ingduplicatemechanisms.WewillextendtheAPIlaterifanyimportantfunctionalityismiss-ing.
我们将力争使得基本的API尽量简单,至少开始的时候是这样的。一般来说,我们希望对实现每个特定的任务只提供一种方案,而避免提供多种方案。如果一些重要的功能遗漏了,那么我们在晚些时候将扩充这个API。
2.6.尽量保持强的、静态的类型
我们希望这个JDBCAPI保持尽量强的类型检查,使得尽可能多的类型信息可以静态地表达。着使得尽可能多的错误可以在编译的时候被发现。
由于SQL本身是动态类型的,所以我们可能会在程序运行的时候遇到类型不能匹配的问题。例如:
当一个程序员在希望SELECT返回一个整数,但是实际返回的是一个字符串“foo”.但是我们依然希望程序员把他们所希望的类型在编译的时候就能够表达清楚,这样我们可以做尽可能多的静态检查。我们也希望在必要的时候能够支持动态类型接口(见第四章)
2.7.使普通任务简化
我们希望普通的任务能够是简单的,而不一般的工作是可行的。
一个普通任务是指一个程序员执行一个简单的没有参数的SQL语句(例如:SELECT,INSERT,UPDATE,DELETE),然后(例如SELECT)处理返回的具有简单类型的元组。一个具有传入参数(INparameter)的SQL语句也是普通的。不那么普通但是也是十分重要的情形是当程序员使用有INOUT,OUT参数的SQL语句。我们
也需要支持读写几兆字节对象的SQL语句,更特别一些的情形包括一个语句返回了多个结果集合。
我们希望元数据(Meatdata)的使用很少的,只是那些熟练的程序员以及开发工具才需要处理的问题。元数据存取函数以及动态类型数据存取函数在这个文档末尾,一般的程序员可以不必关心这些章节。
2.8.不同的功能让不同的方法(函数)来实现
(“方法”的原文是:method,这样翻译是跟VB的)一种界面设计风格是使用很少的过程,提供许多作为参数传递的控制标志,这样它们可以用来影响很大一个范围内的各种行为。来表达不同的功能。这趋向与使用很多的方法,但是每个方法都比较同意理解。
一般来说,Java内核类使用不同的方法(method)。这个步骤的主要优点是开始学习基本界面的程序员可以不必被那些与复杂功能相关的参数所困扰。我们力图在JDBC接口上也采用相同的策略。一般来说采用不同的方法而不是采用不同的标志和多用途的方法。
3.接口概貌
接口分为两个层次,一个是面向程序开发人员的JDBCAPI。另外一个是底层的JDBCDriverAPI。
3.1.JDBCAPI
JDBCAPI被描述成为彝族抽象的Java接口,似的应用程序远可以对某个数据库打开连接,执行SQL语句并且处理结果。错误!嵌入对象无效。
最重要的接口是:
java.sql.DriverManager处理驱动的调入并且对产生新的数据库连接提供支持。
java.sql.Connection代表对特定数据库的连接。
java.sql.Statement代表一个特定的容器,来对一个特定的数据库执行SQL语句。
java.sql.ResultSet控制对一个特定语句的行数据的存取。其中java.sql.Statement又有两个子类型:
1.java.sql.PreparedStatement用于执行预编译的SQL语句。
2.java.sql.CallableStatement用于执行对一个数据库内嵌过程的调用。
下面的章节对JDBC是如何运行的提供了更多描述,整个定义见第13章。另外第15章描述了系统如果获取数据库的元数据信息。
3.2.JDBCDriverAPI
java.sql.Driver在第9章有完整的定义了.大部分JDBC驱动只需要完成这些JDBCAPI所定义的抽象类就可以了。特别地,所有的driver必须提供对java.sql.Connection,java.sql.State-ment,java.sql.Prepared-Statement,andjava.sql.ResultSet的实现。如果目标DBMS提供有OUT参数的内嵌过程,那么还必须提供java.sql.CallableStatement接口。
每个databasedriver必须提供一个类:java.sql.Driver以使得系统可以由java.sql.DriverManager来管理。
一个显然的driver是在ODBC之上提供对JDBC的实现,从而提供与ODBC接口的JDBC-ODBC桥,就象前面的图所显示的.由于JDBC放在ODBC之后,所以实现起来简单而且高效。另外一个有用的驱动直接接触数据库无关的网络协议。发布一个协议允许多个服务器实现的方法,例如在ODBC或者特定的DBMS上(尽管已经有了一些使用固定协议的产品,但是我们不打算对它们实现标准化。),是可取的。
4.JDBC使用场合
BeforelookingatspecificsoftheJDBCAPI,anunderstandingoftypicalusescenariosishelp-ful.Therearetwocommonscenariosthatmustbetreateddifferentlyforourpurposes:appletsandapplications.
在看JDBCAPI之前了解一下典型的使用场合是有帮助的。通常有两种情形必须分别对待:applet和application.
4.1.Applet
目前Java使用的最多的从网络中下载的applet,它们作为web文件的一个部分。当中有数据库存取applet和能够使用JDBC来接触数据库的applet。
例如,一个用户可能下载一个显示股票历史价格图的applet。这个applet通过internet来从关系数据库中获得股票历史价格。最一般的情况里面,对applet的使用是通过不可靠的边界的。例如从另外一个公司或者Internet上获得这些applet。于是称这个情况为"Internet"场合。然而applet也可能通过局域网下载。在这个情况里面,客户机的安全都还是一个问题。
典型的applet在几个方面与传统的数据库应用程序有所不同:
1.不可靠的applet被严格地限制在他们被允许执行的的操作上。特别地,不允许他们存取本地的文件,切不允许他们对任意的数据库建立网络连接。
2.就标识和连接网上数据库来说,Internet环境里面的applet面临新的问题。
3.当数据库可能与你相隔万里的时候,效率的考虑也有所不同了。与局域网相比,Internet上数据库applet可能会碰到十分不同的反应时间。
4.2.Application
Java也可以用来建立普通的应用,从而想一般的应用一样在客户机上使用。我们相信随着开发工具越来越多,人们开始认识到提高程序生产效率的必要性,以及Java的其他优点,Java的这种用法将越来越流行。在这种方式里面,Java的代码是可以信赖的,且被允许读写文件打开网络连接等等,就想其他的应用程序代码一样。
也许这些Java应用使用的最多的是在一个公司内部或者在Intranet上,所以不妨成为Intranet场合。例如一个公司希望利用Java及其GUI构件工具来建立他的基于合作数据模式的合作软件。这些应用程序将存取局域网或者广域网的数据。Java应用可以作到这些。
Java应用程序场合和Intranet场合与applet场合有诸多不同。例如标定一个数据库最自然的方式是用一个数据库的名字,就象//"Customers"和"Personnel"这样。然后用户希望系统能够定位具体的机器,DBMS,JDBCdriver,和Java应用程序。
4.3.其他场合
还有其他一些有趣的场合:
1.已验证的applet(Trustedapplets)是指那些已经被Java虚拟机器认定是可以信赖的applet。他们之所以被认为是可信的是因为他们已经对上了特定的密匙,或者用户认为从特定来源来的applet是可信的。在安全的方面上他们与应用(appliction)相同,但是其他方面(例如定位一个数据库)与则与applet相似。
2.与直接从JavaGUI出发用客户/服务器模式来度曲DBMS服务器不同,三层存取方式可能被使用。在这个场合里面,Java应用程序对中间层的服务发出调用,中间层的服务在网上,它又再去调用数据库。这些调用可能通过RPC(remoteprocedurecall)或者ORB(objectrequestbroker)。在这两种场合里面,中间层最好使用一个对象变化。我们希望三层结构会变得越来越普遍,因为对于MIS管理者来说,这可以使得他们有机会在公共数据库上显式地定义合法操作等。同时三层结构可以提供许多效率上的好处。
目前中间层一般用C或者C这样的语言来完成。通过优化编译器把把Java字节代码翻译成为高效的机器代码,中间层也可以用Java来实现。Java有许多优良特性(健壮性,安全性,多线程)可以达到中间层需要达到的目的。
5.安全性考虑
作为网络上的语言JAVA必须十分注安全性的考虑。基于上面的讨论,JDBC的两种主要使用场合里面,我们必须考虑安全性问题:
在Javaapplications的场合里面Java代码是本地的,所以也是"trusted",没有验证的Javaapplet代码不可以存取本地的以及其他网络的数据。
5.1.JDBC和未验证的applet
JDBC首先必须符合JAVA的一般安全规则。另外:
JDBC必须认为没有验证的applets是不可靠的。lJDBC不可以让不可靠的applets存取本地数据库。
一个已经向JDBCDriverManager注册的是JDBCDriver只能存取它所来的数据源。
一个applet也只能向它所Download来的服务器来存取数据。
如果JDBC驱动层如果完全确信对一个数据库服务器打开连接不会引起认证或者权限问题(可能由网上随机主机上运行的程序引起),那么它就允许applet打开这样的连接。数据库服务器不通过IP地址来限制存取是相当少的,主要是为了举例。(当心,这一段话我可能翻译反了!!!大家看看原文。)这些限制是相当烦琐的。不过他们与对一般applet的限制是一致的我们没有必要放开这些限制。
分享到:
相关推荐
【JDBC编程基础】 在Java开发中,与数据库交互是一项重要的任务,而JDBC(Java Database Connectivity)就是Java平台的标准接口,它允许Java应用程序连接到各种数据库,实现数据的读写操作。本节主要讲解了JDBC编程...
总的来说,JDBC编程是Java程序员必须掌握的基础技能之一,它不仅可以帮助我们理解数据库操作的底层原理,还可以提高我们解决实际问题的能力。对于初学者来说,通过学习JDBC编程,可以加深对Java和数据库的理解,为...
数据库基础与JDBC编程技术是IT领域中至关重要的部分,主要涉及如何管理和操作数据以及如何通过Java语言与数据库进行交互。下面将详细讲解这两个主题。 首先,我们来探讨数据库基础。数据库是一个组织和存储数据的...
**JDBC编程实例详解** Java Database Connectivity(JDBC)是Java平台中用于访问数据库的标准Java API,它允许Java应用程序与各种数据库进行交互。本篇将深入讲解JDBC编程实例,帮助开发者更好地理解和运用JDBC技术...
(1)熟练掌握JDBC操作数据库的整个过程; (2)利用预处理语句操作数据库; (3)掌握可滚动和可更新的结果集的基本操作方法; (4)理解JDBC中实现事务处理的基本方法; (5)理解数据库连接池的基本原理和思想,...
5. **JDBC编程设计**:在JSP中,使用JDBC通常涉及加载驱动、建立连接、创建Statement或PreparedStatement对象、执行SQL语句、处理结果集,以及关闭资源。PreparedStatement能防止SQL注入攻击,性能也更好,因为它...
《老罗Android开发视频教程》中的“服务器端JDBC编程”部分主要讲解了如何在Android应用中与远程数据库进行交互,使用Java Database Connectivity (JDBC) 技术来实现这一目标。JDBC是Java中用于访问数据库的标准接口...
**JDBC编程与Java基础知识详解** 在IT领域,Java数据库连接(JDBC)是Java程序访问数据库的关键技术,它提供了一组标准API,使得开发者能够用Java语言与各种类型的数据库进行交互。本篇将深入探讨JDBC编程的核心...
本文档是关于 JDBC 编程的总结,涵盖了 JDBC 的基础知识、JDBC API 介绍、JDBC 驱动程序的类型、JDBC 连接到 Oracle、JDBC 程序优化、JDBC 分页、JDBC 封装、JDBC 与 Swing 的集成开发等内容。 作为一名软件开发者...
总之,JDBC是Java开发中的重要组成部分,理解并熟练掌握JDBC编程技术,不仅可以帮助开发者更好地与各种数据库交互,也为使用ORM框架打下坚实基础。随着技术的发展,虽然现代应用更多地倾向于使用ORM,但了解JDBC的...
博文链接:https://snowyvalley.iteye.com/blog/65793
在Java Web开发中,JDBC(Java Database Connectivity)是一个核心组件,它允许Java应用程序与各种数据库进行交互。...通过学习这些内容,开发者能够熟练掌握JDBC编程,为Java Web应用的数据库操作打下坚实基础。
在JDBC编程中,主要涉及以下几个步骤: 1. **创建数据库URL**: 数据库URL是Java程序连接数据库的关键,它包含了数据库类型、服务器地址、端口号、数据库名称等信息。例如,对于MySQL数据库,一个典型的URL是`jdbc...
**JDBC编程笔记** JDBC(Java Database Connectivity)是Java语言中用来规范客户端程序如何连接数据库的应用程序接口,提供了诸如查询和更新数据库中数据的方法。本笔记将深入探讨JDBC的核心概念、使用步骤以及常见...
了解JDBC的概念及必要性 了解JDBC驱动程序类型 理解JDBC 程序的结构 运用JDBC进行数据库编程
**JDBC编程实例详解** Java Database Connectivity(JDBC)是Java平台中用于访问数据库的标准Java API,它允许Java程序员在应用程序中执行SQL语句,从而实现对数据库的增删查改操作。本教程将深入探讨JDBC编程实例...