《计算机毕业设计论文毕业设计外文翻译资料.doc》由会员分享,可在线阅读,更多相关《计算机毕业设计论文毕业设计外文翻译资料.doc(8页珍藏版)》请在三一办公上搜索。
1、外文出处:Exploiting Software How to Break CodeBy Greg Hoglund, Gary McGraw Publisher : Addison Wesley Pub Date : February 17, 2004 ISBN : 0-201-78695-8译文标题:JDBC接口技术 译文: JDBC是一种可用于执行SQL语句的JavaAPI(ApplicationProgrammingInterface应用程序设计接口)。它由一些Java语言编写的类和界面组成。JDBC为数据库应用开发人员、数据库前台工具开发人员提供了一种标准的应用程序设计接口,使开发人员
2、可以用纯Java语言编写完整的数据库应用程序。 一、ODBC到JDBC的发展历程 说到JDBC,很容易让人联想到另一个十分熟悉的字眼“ODBC”。它们之间有没有联系呢?如果有,那么它们之间又是怎样的关系呢? ODBC是OpenDatabaseConnectivity的英文简写。它是一种用来在相关或不相关的数据库管理系统(DBMS)中存取数据的,用C语言实现的,标准应用程序数据接口。通过ODBCAPI,应用程序可以存取保存在多种不同数据库管理系统(DBMS)中的数据,而不论每个DBMS使用了何种数据存储格式和编程接口。 1ODBC的结构模型 ODBC的结构包括四个主要部分:应用程序接口、驱动器管
3、理器、数据库驱动器和数据源。 应用程序接口:屏蔽不同的ODBC数据库驱动器之间函数调用的差别,为用户提供统一的SQL编程接口。 驱动器管理器:为应用程序装载数据库驱动器。 数据库驱动器:实现ODBC的函数调用,提供对特定数据源的SQL请求。如果需要,数据库驱动器将修改应用程序的请求,使得请求符合相关的DBMS所支持的文法。 数据源:由用户想要存取的数据以及与它相关的操作系统、DBMS和用于访问DBMS的网络平台组成。 虽然ODBC驱动器管理器的主要目的是加载数据库驱动器,以便ODBC函数调用,但是数据库驱动器本身也执行ODBC函数调用,并与数据库相互配合。因此当应用系统发出调用与数据源进行连接
4、时,数据库驱动器能管理通信协议。当建立起与数据源的连接时,数据库驱动器便能处理应用系统向DBMS发出的请求,对分析或发自数据源的设计进行必要的翻译,并将结果返回给应用系统。 2JDBC的诞生 自从Java语言于1995年5月正式公布以来,Java风靡全球。出现大量的用java语言编写的程序,其中也包括数据库应用程序。由于没有一个Java语言的API,编程人员不得不在Java程序中加入C语言的ODBC函数调用。这就使很多Java的优秀特性无法充分发挥,比如平台无关性、面向对象特性等。随着越来越多的编程人员对Java语言的日益喜爱,越来越多的公司在Java程序开发上投入的精力日益增加,对java语
5、言接口的访问数据库的API的要求越来越强烈。也由于ODBC的有其不足之处,比如它并不容易使用,没有面向对象的特性等等,SUN公司决定开发一Java语言为接口的数据库应用程序开发接口。在JDK1x版本中,JDBC只是一个可选部件,到了JDK11公布时,SQL类包(也就是JDBCAPI)就成为Java语言的标准部件。 二、JDBC技术概述 JDBC是一种可用于执行SQL语句的JavaAPI(ApplicationProgrammingInterface,应用程序设计接口)。它由一些Java语言写的类、界面组成。JDBC给数据库应用开发人员、数据库前台工具开发人员提供了一种标准的应用程序设计接口,使
6、开发人员可以用纯Java语言编写完整的数据库应用程序。 通过使用JDBC,开发人员可以很方便地将SQL语句传送给几乎任何一种数据库。也就是说,开发人员可以不必写一个程序访问Sybase,写另一个程序访问Oracle,再写一个程序访问Microsoft的SQLServer。用JDBC写的程序能够自动地将SQL语句传送给相应的数据库管理系统(DBMS)。不但如此,使用Java编写的应用程序可以在任何支持Java的平台上运行,不必在不同的平台上编写不同的应用。Java和JDBC的结合可以让开发人员在开发数据库应用时真正实现“WriteOnce,RunEverywhere!” Java具有健壮、安全、
7、易用等特性,而且支持自动网上下载,本质上是一种很好的数据库应用的编程语言。它所需要的是Java应用如何同各种各样的数据库连接,JDBC正是实现这种连接的关键。 JDBC扩展了Java的能力,如使用Java和JDBCAPI就可以公布一个Web页,页中带有能访问远端数据库的Applet。或者企业可以通过JDBC让全部的职工(他们可以使用不同的操作系统,如Windwos,Machintosh和UNIX)在Intranet上连接到几个全球数据库上,而这几个全球数据库可以是不相同的。随着越来越多的程序开发人员使用Java语言,对Java访问数据库易操作性的需求越来越强烈。 MIS管理人员喜欢Java和J
8、DBC,因为这样可以更容易经济地公布信息。各种已经安装在数据库中的事务处理都将继续正常运行,甚至这些事务处理是存储在不同的数据库管理系统中;而对新的数据库应用来说,开发时间将缩短,安装和版本升级将大大简化。程序员可以编写或改写一个程序,然后将它放在服务器上,而每个用户都可以访问服务器得到最新的版本。对于信息服务行业,Java和JDBC提供了一种很好的向外界用户更新信息的方法。 1JDBC的任务 简单地说,JDBC能完成下列三件事: 1)同一个数据库建立连接; 2)向数据库发送SQL语句; 3)处理数据库返回的结果。 2JDBC一种底层的API JDBC是一种底层API,这意味着它将直接调用SQ
9、L命令。JDBC完全胜任这个任务,而且比其他数据库互联更加容易实现。同时它也是构造高层API和数据库开发工具的基础。高层API和数据库开发工具应该是用户界面更加友好,使用更加方便,更易于理解的。但所有这样的API将最终被翻译为象JDBC这样的底层API。目前两种基于JDBC的高层API正处在开发阶段。 1)SQL语言嵌入Java的预处理器。虽然DBMS已经实现了SQL查询,但JDBC要求SQL语句被当作字符串参数传送给Java程序。而嵌入式SQL预处理器允许程序员将SQL语句混用:Java变量可以在SQL语句中使用,来接收或提供数值。然后SQL的预处理器将把这种JavaSQL混用的程序翻译成带
10、有JDBCAPI的Java程序。 2)实现从关系数据库到Java类的直接映射。Javasoft和其他公司已经宣布要实现这一技术。在这种“对象关系”映射中,表的每一行都将变成这类的一个实例,每一列的值对应实例的一个属性。程序员可以直接操作Java的对象;而存取所需要的SQL调用将在内部直接产生。还可以实现更加复杂的映射,比如多张表的行在一个Java的类中实现。 随着大家对JDBC兴趣的不断浓厚,越来越多的开发人员已经开始利用JDBC为基础的工具进行开发。这使开发工作变得容易。同时,程序员也正在开发对最终用户来说访问数据库更加容易的应用程序。 3JDBC和ODBC及其他API的比较 到目前为止,微
11、软的ODBC可能是用得最广泛的访问关系数据库的API。它提供了连接几乎任何一种平台、任何一种数据库的能力。那么,为什么不直接从Java中直接使用ODBC呢? 回答是可以从Java中使用ODBC,但最好在JDBC的协助下,用JDBCODBC桥接器实现。那么,为什么需要JDBC呢?要回答这个问题,有这么几个方面: 1)ODBC并不适合在Java中直接使用。ODBC是一个C语言实现的API,从Java程序调用本地的C程序会带来一系列类似安全性、完整性、健壮性的缺点。 2)其次,完全精确地实现从C代码ODBC到JavaAPI写的ODBC的翻译也并不令人满意。比如,Java没有指针,而ODBC中大量地使
12、用了指针,包括极易出错的空指针“void”。因此,对Java程序员来说,把JDBC设想成将ODBC转换成面向对象的API是很自然的。 3)ODBC并不容易学习,它将简单特性和复杂特性混杂在一起,甚至对非常简单的查询都有复杂的选项。而JDBC刚好相反,它保持了简单事物的简单性,但又允许复杂的特性。 4)JDBC这样的JavaAPI对于纯Java方案来说是必须的。当使用ODBC时,人们必须在每一台客户机上安装ODBC驱动器和驱动管理器。如果JDBC驱动器是完全用Java语言实现的话,那么JDBC的代码就可以自动的下载和安装,并保证其安全性,而且,这将适应任何Java平台,从网络计算机NC到大型主机
13、Mainframe。 总而言之,JDBCAPI是能体现SQL最基本抽象概念的、最直接的Java接口。它建构在ODBC的基础上,因此,熟悉ODBC的程序员将发现学习JDBC非常容易。JDBC保持了ODBC的基本设计特征。实际上,这两种接口都是基于XOPENSQL的调用级接口(CLI)。它们的最大的不同是JDBC是基于Java的风格和优点,并强化了Java的风格和优点。 最近,微软又推出了除了ODBC以外的新的API,如RDO,ADO和OLEDB。这些API事实上在很多方面上同JDBC一样朝着相同的方向努力,也就是努力成为一个面向对象的,基于ODBC的类接口。然而,这些接口目前并不能代替ODBC,
14、尤其在ODBC驱动器已经在市场完全形成的时候,更重要的是它们只是ODBC的“漂亮的包装”。 4JDBC两层模型和三层模型 JDBC支持两层模型,也支持三层模型访问数据库。 如图所示,两层模型中,一个java Appple或者一个JAva应用直接同数据库连接。这就需要能直接被访问的数据库进行连接的JDBC驱动器。用户的SQL语句被传送给数据库,而这些语句执行的结果将被传回给用户。数据库可以在同一机器上,也可以另一机器上通过网络进行连接。这被称为“Client/Server”结构,用户的计算机作为Client,运行数据库的计算机作为Server。这个网络可是intranet,比如连接全体雇员的企业
15、内部网,当然也可以是internet。 如图所示,在三层模型中,命令将被发送到服务的“中间层”,而“中间层”将SQL语句发送到数据库。数据库处理SQL语句并将结果返回“中间层”,然后“中间层”将它们 返回用户。MIS管理员将发现三层模型很有吸引力,因为“中间层”可以进行对访问的控制并协同数据库的更新,另一个优势就是如果有一个“中间层”用户就可以使用一个易用的高层的API,这个API可以由“中间层”进行转换,转换成底层的调用。而且,在许多情况下,三层模型可以提供更好的性能。 到目前为止,“中间层”通常还是用C或C+实现,以保证其高性能。但随着优化编译器的引入,将java的字节码转换成高效的机器码
16、,用java来实现“中间层”将越来越实际。而JDBC是允许从一个java“中间层”访问数据库的关键。指导教师评语: 签字: 年 月 日JDBC Interface Technology JDBC is a SQL statement can be used for the implementation of the JavaAPI (ApplicationProgrammingInterface Application Programming Interface). It consists of a number of Java Language class and interface com
17、ponents. JDBC for database application developers, database developers Front Desk Tools provides a standard application programming interface, So that developers can use pure Java language to prepare a complete database application. One, ODBC to JDBC course of development Speaking of JDBC, it is tem
18、pting to think of another very familiar with the word ODBC. There is no contact between them then? If there is, then between them is What kind of relationship? ODBC is the English abbreviation OpenDatabaseConnectivity. It is a used in related or not related to database management system (DBMS) to ac
19、cess data And implementation using C language, the standard application data interface.通过ODBCAPI, applications can access the stored in a variety of database management system (DBMS) Data, regardless of what the use of each DBMS data storage format and programming interface. 1. ODBC structural model
20、 ODBC structure includes four main parts: application program interface, the drive manager, database driver and data source. Application Programming Interface: Shielded different ODBC database drivers the difference between the function call to provide users with a unified SQL programming interface.
21、 Driver Manager: In order to load the database application drives. Database drive: implementation of the ODBC function calls to provide data source specific SQL request. If necessary, the database driver will be requested to amend application Order to make the request in accordance with the relevant
22、 DBMS supported by the grammar. Data Source: by the user wants to access the data, as well as with its associated operating system, DBMS and the DBMS used to access the network platform. Although the ODBC Driver Manager the main purpose of the database are loaded drive in order to ODBC function call
23、, but the database itself drive the implementation of ODBC Functions Call, and with the database each other. Thus, when the calling application systems and data sources to connect, the database driver can manage communications protocol. When set up with Data source connectivity, database-driven appl
24、ication system is able to handle the request sent to the DBMS of analysis or data source from the bottom of the design of the necessary translation, and The results back to the applications. 2. JDBC birth Since the Java language in May 1995 has been officially announced, Java swept the world. Emerge
25、nce of many languages with java program, including the database should be Procedure. Because of absence of a Java language API, the programmer has to program in Java language ODBC add C function call. This makes Java a lot of outstanding Unable to give full play to the characteristics, such as platf
26、orm independence, object-oriented characteristics. As more and more programmers to the Java language increasingly popular, more and more public Secretary for Program Development in Java on the increasing energy input on the java language interface to access the database of the API requirements becom
27、e stronger and stronger. Also because of the ODBC has its shortcomings The Department, such as it is not easy to use, there is no object-oriented.features and so on, SUN One company decided to develop Java language database interface application development interface. At JDK1. x version, JDBC is an
28、optional component to theJDK1.1announcement, SQL-type package (that is, JDBCAPI) has become the standard Java language, the Department of Pieces. Second, JDBC Technical Overview JDBC is a SQL statement can be used for the implementation of the JavaAPI (ApplicationProgrammingInterface, Application Pr
29、ogramming Interface). It consists of a number of Writing Java language class, interface components. JDBC for database application developers, database developers Front Desk Tools provides a standard Application Programming Access The mouth, so that developers can use pure Java language to prepare a
30、complete database application. Through the use of JDBC, developers can easily send SQL statements to virtually any kind of database. In other words, developers do not have to write a Program Access Sybase, write another program to visit Oracle, write a program to visit Microsofts SQLServer. Writing
31、with JDBC procedures can automatically SQL Statement sent to the appropriate database management system (DBMS). Not only that, the use of Java applications can be prepared at any support running on Java platform, not Must in the preparation of different platforms on different applications. The combi
32、nation of Java and JDBC allows developers to develop database applications really achieve WriteOnce, RunEverywhere! Java has a robust, secure, easy-to-use and other characteristics, but also support the automatic downloading, in essence, is a good database application programming language. It needs
33、Java application is how to work with various database connection, JDBC is the key to achieve this connection. JDBC expanded the ability of Java, such as the use of Java and JDBCAPI can publish a Web page, page with access to remote databases Ap plet. Either Enterprises through JDBC to allow all the
34、workers (who can use different operating systems, such as Windwos, Machintosh and UNIX) at In tranet up to connect to the On a number of global databases, which can be several global databases are not identical. As more and more developers use Java language, Java access to data Treasury ease the dem
35、and for more and more strongly. MIS managers like Java and JDBC, as it can more easily publish information economically. Variety has been installed in the database of affairs will continue to deal with Normal operation, and even deal with these matters are stored in different database management sys
36、tems; and the new database application, the development time will be shortened, installation and version This upgrade will be greatly simplified. Programmers can write or rewrite a program, and then put it on the server, each user can access the server to beup-to-date Version. For the information se
37、rvice industry, Java and JDBC provides a good user to update information to the outside world approach. 1. JDBC-mission Easy to say, JDBC can complete the following three things: 1) set up with a database connection; 2) Send SQL statements to the database; 3) deal with the results of the database ba
38、ck. 2. JDBC-an underlying API JDBC is an underlying API, which means that it will direct calls to SQL commands. JDBC fully qualified for this mission, but also than other database connectivity is more easily Now. It is also constructed at the same time high-level API and database development tools.
39、High-level API and database development tools should be more friendly user interface, the use of more side Then, more easily understandable. However, all this API will eventually be translated into JDBC such as the bottom of API. At present, two high-level API based on JDBC is indevelopment stage Pa
40、ragraph. 1) SQL language embedded Java pre-processor. While the DBMS has achieved the SQL query, but the JDBC requirements of SQL statements as a string parameter transmitted to the Java way Sequence. The embedded SQL preprocessor allows a programmer to mix SQL statements: Java variables can be used
41、 in SQL statements to receive or provide the value. And the pre-SQL This processor will be Java / SQL mix procedures translated into the Java program with JDBCAPI. 2) implementation from the relational database to the Java type of direct mapping. Javasoft and other companies have announced plans to
42、achieve this technology. At this object / relational Mapping table of each line will become an example of this type, each column corresponds to the value of a property instance. Java programmers can directly operate the object; and depositors Check required by the SQL call to be a direct consequence
43、 of in-house. Can also achieve more complex mapping, such as tables of many firms of a Java implementation of the class. With the U.S. on the continuing strong interest in JDBC, a growing number of developers have begun to use JDBC-based tools for development. This development work has become Easy.
44、At the same time, programmers are also being developed for end-users easier access to the database applications. 3. JDBC and ODBC, and other API Comparison So far, Microsofts ODBC may be the most widely used relational database access API. It provides a connection to almost any platform, any one of
45、a few According to the ability of the Treasury. Well, why not directly from Java directly using ODBC it? The answer is available from Java using ODBC, but preferably by the help of JDBC, using JDBC-ODBC bridge implementation. So why does JDBC necessary? To return Answer this question, there are so f
46、ew aspects: 1) ODBC is not suitable for direct use in Java. ODBC is a C language implementation of the API, from Java program to call the local C procedure will bring about a series of similar security Wide, integrity, robustness shortcomings. 2) Secondly, completely accurate implementation ODBC fro
47、m C code to the ODBC Writing JavaAPI translation is also not satisfactory. For instance, Java no pointer, and ODBC Medium Substantial use of indicators, including the highly error null pointer void *. Thus, Java programmers, the idea put JDBC to ODBC converted into object-oriented The API is very na
48、tural. 3) ODBC is not easy to study, it features easy and complex characteristics of mixed together, even for very simple query options are complex. The JDBC just Instead, it has maintained a simple and easy things, but the characteristics of the complex permit. 4) JDBC such JavaAPI for pure Java programs are necessary. When using ODBC, people must be on each client machine to install ODBC drivers and Driver Manager. If the JDBC driver to use Java language are fully realize, then the JDBC code can be automatical