- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第4章 JavaEE基础应用教程之Hibernate应用.ppt
4.5.2 Hibernate与Struts 2整合应用实例——开发学生选课系统 对应Action实现类,可以发现是一个新的Action类名为KcAction.java,代码如下: package org.action; import java.util.List; import java.util.Map; import org.dao.KcDao; import org.dao.imp.KcDaoImp; import com.opensymphony.xwork2.ActionContext; import com.opensymphony.xwork2.ActionSupport; public class KcAction extends ActionSupport{ public String execute()throws Exception{ KcDao kcDao=new KcDaoImp(); List list=kcDao.getAll(); Map request=(Map)ActionContext.getContext().get(request); request.put(list, list); return SUCCESS; } } 4.5.2 Hibernate与Struts 2整合应用实例——开发学生选课系统 成功页面allKc.jsp。 在每个课程的后面有【选修】超链接,提交给selectKc.action,Action的配置如下: action name=selectKc class=org.action.XsAction method=selectKc result name=success/selectKc_success.jsp/result result name=error/selectKc_fail.jsp/result /action 对应Action实现类的方法(由于是学生选课,所以该方法在XsAction中)。 4.5.2 Hibernate与Struts 2整合应用实例——开发学生选课系统 成功页面selectKc_success.jsp: %@ page language=java pageEncoding=UTF-8% html body bgcolor=#D9DFAA 你已经成功选择该课程! /body /html 失败页面selectKc_fail.jsp: %@ page language=java pageEncoding=UTF-8% html body bgcolor=#D9DFAA 你已经选择该课程,请不要重复选取! /body /html 10. 部署运行 完成以后,部署项目,启动Tomcat,就可以运行项目。一个简易的学生选课系统就形成了。 4.4.1 Hibernate批量处理 下面使用HQL批量更新把课程表中的XS修改为30。由于这里是用Hibernate操作,故HQL要用类对象及其属性。 Session session=HibernateSessionFactory.getSession(); Transaction ts=session.beginTransaction(); //在HQL查询中使用update进行批量更新 Query query=session.createQuery(update Kcb set xs=30); query.executeUpdate(); mit(); HibernateSessionFactory.closeSession(); 4.4.1 Hibernate批量处理 (2)绕过Hibernate调用JDBC进行批量更新 由于这里是直接操作数据库,故要操作对应表,而不是类。 Session session=HibernateSessionFactory.getSession(); Transaction ts=session.beginTransaction(); Connection conn=session.connection(); try { Statement stmt=conn.createStatement(); //调用JDBC的update进行批量更新 stmt.executeUpdate(update KCB set XS=30); } catch (SQLException e) { e.printStackTrace(); } mit(); HibernateSessionFactory.closeSession(); 4.4.1 Hibernate批量处理 3. 批量删除 (1)由Hiberna
文档评论(0)