毕业设计英文外文翻译在Eclipse中使用Hibernate.docx
《毕业设计英文外文翻译在Eclipse中使用Hibernate.docx》由会员分享,可在线阅读,更多相关《毕业设计英文外文翻译在Eclipse中使用Hibernate.docx(33页珍藏版)》请在冰点文库上搜索。
毕业设计英文外文翻译在Eclipse中使用Hibernate
附录C英文译文
在Eclipse中使用Hibernate
摘要:
最近我开始使用Eclipse作为我的开发环境,我开始研究其他人提供的对Eclipse的扩展。
例如,当用到xml文件时,我使用XMLBuddy插件.在这篇文章中,我们将探索其中之一:
HibernateSynchronizer.。
介绍
最近我开始使用Eclipse作为我的开发环境,部分原因是因为在我进行开发的许多平台上都可以使用Eclipse来工作,还有部分原因是因为Eclipse是展示人人皆可作出贡献的开放、可扩展环境的优势的一个极好的例子。
我开始研究其他人提供的对Eclipse的扩展。
例如,当用到xml文件时,我使用XMLBuddy插件。
该插件对于我的工作很有助益。
因为最近一直在写Developer'sNotebook,所以我很想知道是不是已经有人写了关于Hibernate的插件,事实上,有好几个这样的插件正在开发。
在这篇文章中,我们将探索其中之一:
HibernateSynchronizer.
HibernateSynchronizer
在我找的和Hibernate有关的插件中,HibernateSynchronizer最令我感兴趣,因为它为我在Developer'sNotebook书中采用的以映射为中心的工作流(mapping-centricworkflow)提供了最好的支持。
(可以用多种方法使用Hibernate,你可能会试试其它一些插件,它们提供的方法可能正是你自己特定环境所要求的)。
事实上,当使用HibernateSynchronizer时,如果你改变了映射文件,你不需要为更新相应的java文件而劳心费神。
当你编辑映射文件时,和Eclipse采取的方法类似,该插件自动更新你的java代码。
还不止于此,还提供了比Hibernate内建的代码生成工具更多的功能:
它为每个映射对象创建一对类(apairofclasses),其中一个是基础类,当你改变映射内容时,它可以随意重写这个类;另一个类作为该基础类的子类,在子类中,你可以添加具体的商业逻辑和另一些代码。
使用这个插件生成java代码时,不用象使用Hibernate内置的代码生成工具那样,担心其它代码(如商业逻辑的代码)会在你的眼皮底下消失。
对于以Hibernate影射文档为基础的方法,还有一些其它的好处,HibernateSynchronizer有一个新编辑器,当编辑这类文件时,为Eclipse添加了智能辅助和自动完成功能。
一个比较好的、以DTD驱动的XML编辑器,如以前提及的XMLBuddy,也可以完成部分功能。
与此相比,HibernateSynchronizer利用对影射文档语义的了解,提供了更进一步的功能。
例如,提供了对属性和影射关系的可视化显示,创建新元素的向导界面,象以上提及的一样,缺省设置情况下,当你编辑影射文档时,编辑器会自动生成数据访问类(data-accessclass).
当然还有其它一些功能,在Eclipse的新建(New)菜单中,提供了一个向导,可以用来创建Hibernate配置文件和映射文件,在包资源浏览器(packageexplorer)和其它一些合适的地方增加了上下文菜单,方便调用和Hibernate相关的功能。
好了,在这些抽象的描述之后,到了开始做实事的时候,当然,这正是你兴趣所在,不然你就不会读这篇文章。
怎么安装和使用呢?
下边一一解释。
安装
HibernateSynchronizer可以用Eclipse内置的更新管理器(UpdateManager)来安装。
对Eclipse2.1和即将发布的Eclipse3的用户提供了不同的更新站点。
(因为用Eclipse作关键性的工作,我仍使用作为产品发行的2.1版。
当我写这篇文章的时候,Eclipse3已经进入了“候选发布”阶段。
我希望当我今夏晚些时候从JavaOne回来时,我可以更新到版本3的产品发行版。
提及这个的主要原因是因为我想强调一下,这些指南是以Eclipse2的角度的来讲解,毫无疑问,一些命令和窗口会在版本3中发生变化,因此,当你使用Eclipse3时,你应当做一些相应的调整。
我印象中HibernateSynchronizer自己的installinstructions是针对Eclipse3,也许这对你有所帮助。
启动Eclipse,顺次单击帮助(Help)->软件更新(SoftwareUpdates)->更新管理器(UpdateManager)来打开更新管理器,当安装/更新(Install/Update)透视图打开之后,在功能更新视图(FeatureUpdates)中用右键单击(如果你用的单键,你需要control-click)。
选择新建(New)->站点书签(SiteBookmark)。
在更新管理器中添加HibernateSynchronizer插件的更新地址
在弹出对话框中,输入适合你的Eclipse版本的插件地址:
·Eclipse2.1:
·Eclipse3:
还需要为新建的书签命名,"HibernateSynchronizer"就是个很贴切的名字。
单击完成(Finish)后,新建的书签就会出现在功能更新(FeatureUpdates),实际安装该插件,单击该书签左边的三角形符号,然后再次单击在书签下边出现的条目左边的三角形符号,继续这个过程,一直到书签下边出现的条目中出现该插件的图标。
单击该条目,就会出现一个可以让你安装的界面,单击InstallNow,让Eclipse引导你完成安装许可协议,你可以看看下边Trade-Offs部分对许可协议的一些讨论。
当你打算在实际的项目中使用该插件时,想必你会仔细研究该协议。
我认为也许好一点,不过该插件基于GPL协议,而不是开放源代码,令人迷惑。
选择安装位置,缺省的已经很好了。
安装没有签名插件时的标准警告。
现在已经完成安装,你需要退出,然后重新启动Eclipse以使所做的更改生效。
看上边的对话框好像说能够自动重新启动Eclipse。
以我的经验,Eclipse只会退出,还是需要你自己手工重新启动。
这可能是MaxOSX平台上Eclipse2.1的一个局限。
Eclipse3已经许诺把对OSX的支持列入第一级别。
无论如何,这只是个小问题。
如果你需要重新启动Eclipse,现在就可以这样做。
安装完之后,接着需要对其对其进行配置,以便在项目中使用。
配置
重新启动Eclipse后,关闭安装/更新透视图。
打开一个使用Hibernate的Java工程.如果你已经完成了Developer'sNotebook,一书中的例子,那么就有几个目录可供你选择,这里以书中第三章中的例子来说明。
第三章是可以在线免费获得的样章,你还可以从该书的站点下载所有例子的源代码。
如果你打算使用其中的一个例子来新建一个Eclipse工程,选择文件(File)->新建(New)->工程(Project),选定工程类型,然后单击下一步(Next),填入该工程名(我填的是"HibernateCh3",如图11所示),不要复选使用缺省检查框(Usedefault),这样你可以告诉Eclipse从哪里找到已经存在的工程目录,单击浏览按钮(Browse)来定位目录。
选定工程目录后可以单击完成(Finish)来创建工程。
不过,一般情况下我喜欢单击下一步(Next)来复查Eclipse为此工程所作的设置(当然,如果发现有些配置不对,总是可以选择回退来修改这些设置。
不过,我总是发现,如果有一个库文件丢失或是其它一些原因,会有非常多的错误和警告信息)。
在当前情况下,我的谨慎有点多余。
Eclipse准确的算出了目录是如何组织以及是用来干什么的,找到我为使用Hibernate和HSQLDB数据库而下载的第三方库(下载和安装的详细过程可以参看书中第一章)。
如此聪明的适应能力是Eclipse优点之一。
图12显示新工程已经打开,准备好可以用来做实验。
从这个图中也可以推断Eclipse不喜欢调整窗口大小使其小到形成合适的屏幕布局。
从现在开始,显示的屏幕截图只显示窗口的一部分,而不是完整的窗口。
下一个需要做的工作是创建一个Hibernate配置文件,提供给HibernateSynchronizer使用。
在src目录中已经有了一个hibernate.properties文件,这是书中例子使用的配置。
这里有个问题,坏消息是HibernateSynchronizer只能使用XML样式的Hibernate配置文件。
这样,就需要把hibernate.properties中的内容移植到XML样式的配置文件hibernate.cfg.xml中。
好消息是,这正是HibernateSynchronizer创建配置文件向导第一次大显身手的时候。
选择文件(File)->新建(New)->其它(Other),然后在弹出对话框选取刚可用的Hibernate类,选取HibernateConfigurationFile,然后单击下一步(Next).
打开向导时,保存文件的位置和在Eclipse中现在选择的文件有关。
请确保把该文件保存在src目录中。
添加其余一些向导需要的信息,这些信息应该和配置文件的版本相一致,如图14中所示。
值得注意的是,和用Ant来控制Hibernate的运行(书中使用就是这种方法)不同,这里你无法控制Hibernate运行时的当前工作目录,因此你需要在URL文件中使用路径的全称。
我自己的添加的URL值(有点难看)为
jdbc:
hsqldb:
/Users/jim/Documents/Work/OReilly/Hibernate/Examples/ch03/data/music.
(如果有人知道怎么让Eclipse或是HibernateSynchronizer使用一个工程特定的目录,你可以告诉我,我很想知道。
因为我才开始使用Eclipse,是个新手。
如果有人告诉我这是可能的,只是因为我不知道怎么做而已,我一点也不会感到吃惊)
添加DriverClass的方法有点奇怪,你需要确定该driver类在该工程的类路径中)。
如果你输入"jdbcD",窗口就会出现这个选择,很容易就可以从中选取一个。
完成后单击Finish来完成创建配置文件。
HibernateSynchronizer现在已经可以开始使用了。
完成创建文件后,配置文件会打开,这时候你就可以看看HibernateXML格式的配置文件的结构和细节。
生成的配置文件
要想测试配置文件是否可用,有一个又快又简单的方法:
使用向导来创建一个影射文件。
选择文件(File)->新建(New)->其它(Other),选取Hibernate类别,然后再选Hibernate影射文件,单击下一步(Next)。
向导出现的时候,其中有些属性已经自动填入了在配置文件中相应属性的值,单击Refresh(确保可以通过这些信息和你的数据库相连)。
和数据库连接后,会显示库中的表,这里只有一个TRACK表。
第一次使用的时候,不知什么原因,需要你指定包含HSQLDB驱动的.jar文件的路径。
好在你只需要指定一次。
只要你认为工作正常(译者注:
显示了数据库中有权限访问的表),单击Cancel。
试验中使用已有的影射文件,不需要实际创建一个。
生成代码
这可能是你一直在等待的部分。
我们能用这个插件来做什么?
好,马上就开始。
为Hibernate影射文档提供一个新的菜单条目。
右击(如果是单键鼠标,在按住Control键的同时点鼠标键)一个影射文档,菜单条目中会显示几个和Hibernate相关的选择,其中有一个和synchronize有关,这是一个手工方法,可以让HibernateSynchronizer产生和该影射文档相对应的数据访问对象。
Synchronizer插件为影射文档提供的几个菜单项
AddMappingReference选项也很有用,当你单击该项时,会把相应的影射文件增加到Hibernate配置文件中,表明该文件是影射文档,因此你不需要在源代码中增加任何信息要求相应的影射文件进行设置。
现在让我们看看选取SynchronizeFiles后的结果。
事情开始变得有趣,出现了两个子包,一个是“base”的DAO,HibernateSynchronizer所有,可以在任何时候重写,一个是继承那些DAO类的商业对象,不会被覆盖,也就给了我们一个机会,可以在其中加入商业逻辑(具体如图18中所示)。
和Hibernate的代码生成工具相比,用该插件生成了更多的类。
这是优点,也可能是一些潜在的缺点,将在Trade-Offs部分进行讨论。
你可以在工程配置文件中选取要生成的类和它们所在的包的结构。
我可以证明这点,但现在的发行版有个bug,,无法访问MacOSX上的配置界面。
针对该bug的一个补丁已经做好了,但仍没有发布。
基于HibernateSynchronizer网页上的例子,和以下这个类一起,用那些新的数据访问对象来试着把一些数据放入数据库中。
看起来和标准的Hibernate代码生成工具生成的版本(在Hibernate:
ADeveloper'sNotebook一书的39-40页)很相似,甚至更简单一些。
因为HibernateSynchronizer生成的类为你的每个数据库操作都创建和提交一个新事务,因此在与此类似的简单情况下,你不需要自己来设置事务(当然,如果你需要把一组操作作为一个单独事务,有很多方法可以做到这点)这里是新版本的代码。
packagecom.oreilly.hh;
importjava.sql.Time;
importjava.util.Date;
importnet.sf.hibernate.HibernateException;
importcom.oreilly.hh.dao.TrackDAO;
importcom.oreilly.hh.dao._RootDAO;
/**
*TrycreatingsomedatausingtheHibernateSynchronizerapproach.
*/
publicclassCreateTest2{
publicstaticvoidmain(String[]args)throwsHibernateException{
//Loadtheconfigurationfile
_RootDAO.initialize();
//Createsomesampledata
TrackDAOdao=newTrackDAO();
Tracktrack=newTrack("RussianTrance","vol2/album610/track02.mp3",
Time.valueOf("00:
03:
30"),newDate(),(short)0);
dao.save(track);
track=newTrack("VideoKilledtheRadioStar",
"vol2/album611/track12.mp3",Time.valueOf("00:
03:
49"),newDate(),
(short)0);
dao.save(track);
//Wedon'tevenneedatrackvariable,ofcourse:
dao.save(newTrack("Gravity'sAngel","/vol2/album175/track03.mp3",
Time.valueOf("00:
06:
06"),newDate(),(short)0));
}
}
当我写这个的时候,有Eclipse在手边真是太好了,我已经忘了当写书中例子的时候多么想念智能代码完成功能,有另外几件事情JDT也发挥了作用。
为了在Eclipse中运行这个简单的程序,需要设置一个新的运行配置。
用CreateTest2.java作为当前文件,选择运行(Run)->运行...(Run...)。
然后单击新建(New),因为该类有一个main()方法,Eclipse推断出要运行该工程的当前类。
Eclipse为新的运行配置取的名字,CreateTest2,很合适。
既然我知道不需要使用JTA,我倒是很想知道为什么Hibernate竟然会使用JTA?
打开Hibernate配置文件,如图16所示,看看是不是HibernateSynchronizer在其中加入了可疑的内容。
看了配置文件后,可以确定,有一些行看起来是罪魁祸首:
net.sf.hibernate.transaction.JTATransactionFactory
java:
comp/UserTransaction
一旦把那些行变成注释后,再次运行程序。
这次,也就是第三次运行成功。
我在自己计算机上运行没有一点错误,数据已经保存到数据库中。
运行antdb这个target(在Developer'sNotebook一书的第一章有相应的解释)可以把表中所有的数据显示出来(不可否认,这也许有点简单)。
如果你跟着这篇文章中顺序来做的,而不是跟着书中步骤一步一步来的,你需要先运行antschema来创建数据库中的表,或是删除以前试验留下的数据。
在Eclipse中运行Ant
你可以在Eclipse内运行Ant的target,方法是用右键单击包资源浏览器(PackageExplorer)中的build.xml文件,选择菜单中的运行Ant(RunAnt),然后在弹出对话框中选择你要运行的target。
这个功能很cool。
在Eclipse中运行Ant
查询数据相当简单、直白,即使HibernateSynchronizer产生了很多辅助方法来使用指定查询,我认为这些没有什么用处,都是运行查询,然后返回包含结果的列表,而不是返回一个Query对象,让你直接使用该对象。
这使你不能使用任何Query提供的、方便的、类型安全(type-safe)的参数设置方法,因为这个,我打算让_RootDAO对象提供一个Session对象,可以用“老式”的方法来使用Hibernate。
公平来说,我认为如果编辑HibernateSynchronizer用来生成代码所使用的模板,就可以生成想要的任何方法,如果有一个项目,要用到该插件,肯定我会试着这么做。
实际上,进一步考虑,当你得到一个活动的Session时,你只能使用Query,而这些DAO对象已经提供为相应功能最佳的实现。
如果你和我在例子中使用查询的方法一样,那就需要你自己来实现session管理。
你能够把session管理内嵌于你自己所写的那一半DAO中,这样可以给你提供两方面的好处。
(译者注:
和有base的javaPOJO对象一样,对于DAO,该插件也生成一对类,一个baseDAO给该插件用,一个是继承该baseDAO的自定义DAO,你可以在其中添加商业逻辑)。
这也是HibernateSynchronizer把类分隔开来如此有用的另一个原因。
对该插件的远见在下边做了一点研究
不管怎么说,下边是我第一次使用的代码,和书中48-49页上的代码功能基本一致:
packagecom.oreilly.hh;
importjava.sql.Time;
importjava.util.ListIterator;
importnet.sf.hibernate.HibernateException;
importnet.sf.hibernate.Query;
importnet.sf.hibernate.Session;
importcom.oreilly.hh.dao.TrackDAO;
importcom.oreilly.hh.dao._RootDAO;
/**
*UseHibernateSynchronizer'sDAOstorunaquery
*/
publicclassQueryTest3{
publicstaticvoidmain(String[]args)throwsHibernateException{
//Loadtheconfigurationfileandgetasession
_RootDAO.initialize();
Sessionsession=_RootDAO.createSession();
try{
//Printthetracksthatwillfitinfiveminutes
Queryquery=session.getNamedQuery(
TrackDAO.QUERY_COM_OREILLY_HH_TRACKS_NO_LONGER_THAN);
query.setTime("length",Time.valueOf("00:
05:
00"));
for(ListIteratoriter=query.list().listIterator();
iter.hasNext();){
TrackaTrack=(Track)iter.next();
System.out.println("Track:
\""+aTrack.getTitle()+
"\","+aTrack.getPlayTime());
}
}finally{
//Nomatterwhat,closethesession
session.close();
}
}
}
TrackDAO为我们提供了一个很好的功能:
静态常数,使用这个功能,可以用来进行指定查询(namedquery),这就消除了由于输入问题而导致运行时错误的任何机会。
我欣赏这个功能。
为该测试类设定运行配置,然后运行,输出结果正和我想的一样。
2Eclipse控制台窗口显示的查询结果
如上所述,这个类运行后,借助于HibernateSynchronizer提供的模型,我想到有一个更好的方法可以实现这个功能。
把查询放到TrackDAO中去,这里才是查询方法真正属于的地方,指定查询(namedquery)是和该DAO关联的映射文件的一个功能。
packagecom.oreilly.hh.dao;
importjava.sql.Time;
importjava.util.List;
importnet.sf.hibernate.HibernateException;
importnet.sf.hibernate.Query;
importnet.sf.hibernate.Session;
importcom.oreilly.hh.base.BaseTrackDAO;
/**
*Thisclasshasbeenautomaticallygenera