用MyEclipse JPA创建项目(三)
MyEclipse 3.15 Style——在线购买低至75折!火爆开抢>>
本教程介绍了MyEclipse中的一些基于PA的功能。 阅读本教程时,了解JPA和实体映射如何与注释一起工作的基本概念将会很有帮助。 在本教程中,您将学习如何:
- 为JPA设置一个项目
- 连接到数据库
- 反向设计一个数据库表来生成实体
- 实现创建、检索、编辑和删除功能
持续时间:30分钟
没有MyEclipse? 现在下载
四、编写应用程序
由于MyEclipse生成了大量的代码,因此您可以快速专注于编写“业务逻辑”,或者更具体地说,“实际执行的代码”。在本节中,您将编写一个带有main方法的Java类,该方法将Productline插入到数据库中,检索并更新它,然后删除。使用这段代码,您应该能够看到在自己的应用程序中使用JPA实体是多么容易,而无需编写JDBC代码或任何其他持久性代码。
4.1 创建一个类
1. 右键单击com.myeclipseide.jpa包,然后选择New>Class。
2. 在Name字段中输入RunJPA,选择Public static void main复选框,然后单击Finish。
在生成新的类和main方法后,您需要编写代码来成功处理Productline的实例。
注意:下面的代码看起来很长很复杂,但这是因为我们试图在一个代码块中显示四个不同的示例。 如果您查看每个操作(保存,加载,更新,删除),它们都不会包含多行代码。
3. 将以下代码添加到main方法中,然后按Ctrl + S进行保存。
/* 1. Create a reference to our ID */
String productLineID = "Men's Shoes"; /* 2. Create a new Productline instance */
Productline newProductline = new Productline(
productLineID,
"Shoes for men.", "Men's Shoes", null); /* 3. Create a DAO instance to use */
ProductlineDAO dao = new ProductlineDAO(); /* 4. Store our new product line in the DB */
EntityManagerHelper.beginTransaction();
dao.save(newProductline);
EntityManagerHelper.commit(); /* 5. Now retrieve the new product line, using the ID we created */
Productline loadedProductline = dao.findById(productLineID); /* 6. Print out the product line information */
System.out.println("*NEW* Product Line [productLine="
+ loadedProductline.getProductline() + ", textDescription="
+ loadedProductline.getTextdescription() + ", image="
+ loadedProductline.getImage() + "]"); /* * 7. Now let's change same value on the product line, and save the
* change
*/
loadedProductline.setTextdescription("Product line for men's shoes.");
EntityManagerHelper.beginTransaction();
dao.save(loadedProductline);
EntityManagerHelper.commit(); /*
* 8. Now let's load the product line from the DB again, and make sure
* it text description changed
*/
Productline secondLoadedProductline = dao.findById(productLineID); System.out.println("*REVISED* Product Line ["
+ "productLine=" + secondLoadedProductline.getProductline()
+ ", textDescription=" + secondLoadedProductline.getTextdescription()
+ ", image=" + secondLoadedProductline.getImage() + "]"); /* 9. Now let's delete the product line from the DB */
EntityManagerHelper.beginTransaction();
dao.delete(secondLoadedProductline);
EntityManagerHelper.commit(); /* * 10. To confirm the deletion, try and load it again and make sure it
* fails
*/
Productline deletedProductline = dao.findById(productLineID); /*
* We use a simple inlined IF clause to test for null and print
* SUCCESSFUL/FAILED
*/
System.out.println("Productline deletion: "
+ (deletedProductline == null ? "SUCCESSFUL" : "FAILED"));
注意: 将事务数据库的代码片段换成事务是一个好主意,所以如果操作失败(例如DB崩溃),那么试图在事务中发生的所有更改都会回滚到它们的原始值,而不是只有一半 工作完成。
上面的代码看起来令人望而生畏,但它背靠背做了很多简单的事情。 例如,如果您只想将新项目存储在数据库中,则只需要程序中步骤1-3的代码,这些代码将三行代码相减(减去注释)即可。 以下是每个编号部分的细目:
- PRODUCTLINE表使用产品线的名称作为主键。 为了使本教程更容易遵循,我们在字符串中定义产品线名称,并在整个代码中重复使用(创建并存储产品线,然后再检索两次)。 您可以多次轻松输入“Men’s Shoes”,我们认为这使得教程更易于遵循。
- 这将创建一个由MyEclipse生成的Productline POJO的新实例,并将插入到数据库中。 为了本教程的目的,这些值并不重要,所以我们只是使用示例信息。
- 这将创建一个要使用的DAO实例。 数据库访问需要DAO,这也是由MyEclipse生成的。
- 这告诉DAO将新的Productline存储在数据库中。 因为你要写一些东西给数据库,所以把保存的调用包装在一个事务中。
- 为了确保Productline正确存储,使用步骤1中定义的ID,我们要求DAO获取Productline,并将结果分配给一个全新的对象,以确保加载的内容来自数据库。 (我们可以将这个值赋给newProductline,但是为了本教程的目的,我们希望非常明显地知道对象来自哪里以及意外地在代码中加载的实例不存在之前)。
- 这将打印出加载实体的值,以确保它是刚存储在数据库中的值。
- 这会更改刚刚加载的POJO上的值,以显示更新记录的工作方式。 然后使用DAO将更改提交回数据库。 再次,这个操作被封装在一个事务中,以确保安全地更改数据库。
- 就像在第5步中一样,使用步骤1中定义的ID从数据库重新加载记录,以确保更新操作有效。 POJO值将被打印出来,以确保新的描述被保存到数据库中。
- 这显示了如何从DB中删除记录。 因为这需要对数据库进行更改,所以此代码被封装在事务中。
- 与步骤8和步骤5类似,为了证明删除起作用,我们尝试使用我们提供的ID从数据库加载实体。 这个操作应该会失败,因为我们已经删除了Productline。 从DAO获得结果后,将使用嵌入式IF子句打印语句以确保结果为空。
更多资讯敬请访问MyEclipse中文网>>
用MyEclipse JPA创建项目(三)的更多相关文章
- 用MyEclipse JPA创建项目
http://www.myeclipsecn.com/learningcenter/persistence-development/myeclipse-jpa/ 用MyEclipse JPA创建项目 ...
- 用MyEclipse JPA创建项目(二)
MyEclipse 3.15 Style——在线购买低至75折!火爆开抢>> [MyEclipse最新版下载] 本教程介绍了MyEclipse中的一些基于PA的功能. 阅读本教程时,了解J ...
- 用MyEclipse JPA创建项目(四)
MyEclipse 3.15 Style——在线购买低至75折!火爆开抢>> [MyEclipse最新版下载] 本教程介绍了MyEclipse中的一些基于PA的功能. 阅读本教程时,了解J ...
- 用MyEclipse JPA创建项目(一)
MyEclipse 3.15 Style——在线购买低至75折!火爆开抢>> [MyEclipse最新版下载] 本教程介绍了MyEclipse中的一些基于JPA的功能. 阅读本教程时,了解 ...
- 使用MyEclipse 2014创建项目
1. 打开MyEclipse 2014,如果是第一次运行,会提示设置workspace路径,如图: WorkSpace路径是指日后你自己利用MyEclipse创建项目时,项目文件的存放路径.通常不要放 ...
- MyEclipse下创建的项目导入到Eclipse中详细的图文配置方法
一.情景再现. 有些人比较喜欢用Myeclipse开发,有些人却比较喜欢用eclipse开发.但是其中有一个问题,Myeclipse里面的项目导入的时候出现了一个小小的问题. 如下: 二.说明问题 导 ...
- 在MyEclipse下创建Java Web项目 入门(图文并茂)经典教程
http://jijiaa12345.iteye.com/blog/1739754 在MyEclipse下创建Java Web项目 入门(图文并茂)经典教程 本文是一篇在Myeclipse下构建Jav ...
- Eclipse和MyEclipse使用技巧--MyEclipse下创建的项目导入到Eclipse中详细的图文配置方法
一.情景再现. 有些人比较喜欢用Myeclipse开发,有些人却比较喜欢用eclipse开发.但是其中有一个问题,Myeclipse里面的项目导入的时候出现了一个小小的问题. 如下: 二.说明问题 导 ...
- MyEclipse下创建的项目 导入eclipse
1.导入在MyEclipse下创建的项目 2.把项目变成Web项目,在项目上右键-->Properties-->选择Project Facets-->点击Convert to fac ...
随机推荐
- mysql-5.7.20-winx64.zip Zip版、解压版MySQL安装
1. zip下载地址: https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.20-winx64.zip 2.官方文档位置: http:// ...
- [AtCoder ARC101D/ABC107D] Median of Medians
题目链接 题意:给n个数,求出所有子区间的中位数,组成另外一个序列,求出它的中位数 这里的中位数的定义是:将当前区间排序后,设区间长度为m,则中位数为第m/2+1个数 做法:二分+前缀和+树状数组维护 ...
- socket编程时使用了inet_ntoa函数,存储到链表中的数据总是自动改变
这和inet_ntoa的返回值有关系: 函数声明:char *inet_ntoa (struct in_addr); 返回点分十进制的字符串在静态内存中的指针. 所在头文件:<arpa/inet ...
- 配置文件(Machine.config、Web.config、App.config)
Machine.config1.该文件在Windows目录下\Microsoft.net\framework\[version]\Config\2.为了提高性能,该文件只包含不同于默认值的设置.并且定 ...
- UVa 120 煎饼
https://vjudge.net/problem/UVA-120 题意:颠倒连续子序列,使之成为升序. 思路:按照从大到小的顺序,依次选择出一个数字进行分析: ①如果该数字已经在正确的位置上,则不 ...
- 在Windows上面使用QT5 (without QTcreator or VS 2017)
在Windows上面使用QT5 (without QTcreator or VS 2017) 本文环境: 最新版 QT 5.12.1 Windows 10 64位 仅考虑动态链接,静态链接不在本文讨论 ...
- 【网络知识】【1】http、tcp/udp、soap的区别
一句话总结: soap信息可以通过http协议包装后通过tcp或udp传输 参考:https://zhidao.baidu.com/question/617706398106243452.html
- 通过设置代理,解决服务器禁止抓取,报“java.io.IOException: Server returned HTTP response code: 403 for URL”错误的方法
java.io.IOException: Server returned HTTP response code: 403 for URL: http:// 这个是什么异常呢? 当你使用java程序检索 ...
- xss脚本注入后端的防护
1.脚本注入最主要的是不要相信用户输入的任何数据,对数据进行转义 可以使用:org.springframework.web.util.HtmlUtils包中的 HtmlUtils.htmlEscape ...
- JSON序列化反序列化
JSON(全称为JavaScript Object Notation) 是一种轻量级的数据交换格式.它是基于JavaScript语法标准的一个子集. JSON采用完全独立于语言的文本格式,可以很容易在 ...