天天看点

JPA学习

jpa是一套对象持久化规范,可以通过多种工具实现它。比如常见的hibernate。按说初学就该照猫画虎的写例子,可是总改不了探究为什么的好奇心。于是在经历了不少曲折和困惑之后,终于把hibernate和eclipselink两种实现的例子都完成了,也体会了一点二者的区别。

先看在eclipse里的默认jpa项目的做法:

新建jpaproject,填写项目名称和targetruntime(因为只是个简单的例子,不需要部署到服务器上,就选了jre),再点几次next之后,就过不去了,因为要求必须使用一个userlibrary。这就是要添加实现jpa的类库。如果使用eclipselink可以选择下载,如果使用hibernate,可以新建一个,然后把hibernate包里的各个jar文件加进来。最终二者就是在persistence.xml文件的描述上有些许区别,这也是jpa规范的目的所在——使代码尽量不要绑定特定的orm框架。下面是示例代码:

hibernate示例代码:

除了包名不同,其他代码一模一样。两个项目也都用的同一张表,先执行这个项目可以自动创建表,再执行上面的项目就不会报错了。

几个小插曲:

noinstall版本的mysql在修改my.ini的时候,增加basedir和datadir路径需要用/分隔,如:d:/soft/mysql,否则启动不了服务

选择创建普通java project也是可以完成示例的。而如果选择创建的是jpa project,每添加一个@entity注释的类,系统就会自动去检查是否增加到了中(没有添加也可以执行,但作为有点强迫症的程序员,看着这个红叉实在是难受),如果不希望系统检查,删掉.project中的语句——<nature>org.eclipse.wst.common.project.facet.core.nature</nature>,重启eclipse即可。

继续阅读