SSH框架項目教程課件第3章第六講_第1頁
SSH框架項目教程課件第3章第六講_第2頁
SSH框架項目教程課件第3章第六講_第3頁
SSH框架項目教程課件第3章第六講_第4頁
SSH框架項目教程課件第3章第六講_第5頁
已閱讀5頁,還剩1頁未讀 繼續免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

重慶正大軟件學院軟件系《MVC框架程序設計》電子教案重慶正大軟件學院軟件系《MVC框架程序設計》課程組重慶正大軟件職業技術學院教案(項目類)授課對象系別軟件系本次課學時4學時年級班次大二章節題目第3章hibernate一對多(注解)目的要求(含技能要求)掌握hibernate注解方式一對多查詢的基本配置本節重點掌握hibernate注解方式一對多查詢的基本配置本節難點掌握hibernate注解方式一對多查詢的基本配置教學方法項目教學法教學用具機房、屏幕廣播問題引入通過用戶注冊案例中出生地的數據來源,從而引出本次課程。難點與重點講解方法引導、分析、講解、實作演示本次課小結課程小結教后禮記討論、思考題、作業(含實訓作業)完成本次課的課堂任務填寫實驗報告任務介紹(5分鐘)改造本章查詢注冊信息(實現多表一對多查詢)任務,使用hibernate注解方式完成,其表結構(如表3.2-1a、表3.2-1b所示)、頁面(如圖3.2-1c所示)均與查詢注冊信息(實現多表一對多查詢)任務一樣。任務解析(50-60分鐘)修改省份實體類Province(增加注解)修改用戶實體類User(增加注解)修改hibernate.cfg.xml配置文件,添加省份實體類和用戶實體類dao層:修改類QueryDao(修改創建Configuration對象代碼)調試運行詳細步驟修改省份實體類Province(增加注解)修改工程的com.zdsoft.domain包下省份實體類Province,加入注解,關鍵代碼如下:@Entity@Table(name="province")publicclassProvince{@Id@GeneratedValue(generator="pkGenerator")@GenericGenerator(name="pkGenerator",strategy="native") intid;//省份流水號@Column(name="name") Stringname;//省份名稱@Column(name="note") Stringnote;//描述@OneToMany(targetEntity=User.class)@JoinColumn(name="province") privateSet<User>users=newHashSet(0);//同一個省份的多個用戶 //以下省略每個成員變量的get/set方法}修改用戶實體類User(增加注解)修改com.zdsoft.domain包下的User.類,增加注解,關鍵代碼如下:@Entity@Table(name="user")publicclassUser{@Id@GeneratedValue(generator="pkGenerator")@GenericGenerator(name="pkGenerator",strategy="native") intid;@Column(name="name") Stringname;@Column(name="userName") StringuserName;@Column(name="password") Stringpassword;@Column(name="sex") Stringsex;@Column(name="age") intage;@Column(name="birth") Datebirth;@Column(name="mobile") Stringmobile;@Column(name="hobbies") Stringhobbies;@Column(name="email") Stringemail; //以下省略每個成員變量的get/set方法}修改hibernate.cfg.xml配置文件,在<session-factory>節點中添加代碼:<mappingclass="com.zdsoft.domain.User"/><mappingclass="com.zdsoft.domain.Province"/>在<session-factory>中去掉或注釋掉下面代碼:<mappingresource="com/zdsoft/domain/User.hbm.xml"/><mappingresource="com/zdsoft/domain/Province.hbm.xml"/>dao層:修改類QueryDao(修改創建Configuration對象代碼)在com.zdsoft.dao包下數據處理類QueryDao中修改創建Configuration對象代碼,關鍵代碼如下:publicclassQueryDao{ //使用hibernate框架注解方式創建sessionFactory對象 SessionFactorysessionFactory=newAnnotationConfiguration().configure().buildSessionFactory(); publicList<Province>query(Stringprovince){ List<Province>ret=null; //編寫查詢的hibernate框架特有的sql語句 Stringhql="fromProvincewhere1=1"; if(null!=province&&!"".equals(province)){ hql=hql+"andname='"+province+"'"; }else{ returnnull;//若沒有輸入省份,查詢結果是無意義的,直接返回null。 } Sessionsession=sessionFactory.openSession(); try{ Queryquery=session.createQuery(hql); ret=query.list(); }catch(HibernateExceptione){ e.printStackTrace(); ret=null; }finally{ if(session!=null){ session.close(); } } returnret; }}調試運行首先,本章3.2節任務中service層、action層、sturts配置文件、頁面相關代碼均可重用,無需修改,然后按照本章3.2節任務準備好查詢的數據(如圖3.2-5a、圖3.2-5b所示),然后將工程發布到服務器,啟動服務器,運行頁面query.jsp,在查詢條件中輸入重慶,可查到兩條省份為重慶的用戶,如圖3.2-1c所示。根據任務提出問題(45-55分鐘)如何使用hibernate注解方式完成多表一對多查詢?問題解析(45-55分鐘)如何使用hibernate注解方式完成多表一對多查詢?實現一對多查詢:以學生信息管理系統根據班級號查詢學生信息為例。【例子3.6-1】改造例子3.2-1,以注解方式實現根據班級id查詢該班級所有學生的信息,并把學生信息列表顯示在查詢頁面中的功能。本例子的頁面(如圖3.2-4d)、數據庫表(表結構如表3.2-2a、表3.2-2b所示)均與3.2-1一樣。步驟1:在eclipse中創建web工程studentInfoManage,并把hibernate,struts2及數據庫所需的jar包拷貝到工程WebContent/WEB-INF/lib目錄下。步驟2:修改com.zdsoft.domain包中的學生實體類Student,添加注解相關配置,該代碼沒有一對多的配置,關鍵代碼如下:@Entity@Table(name="student")publicclassStudent{@Id@GeneratedValue(generator="pkGenerator")@GenericGenerator(name="pkGenerator",strategy="native")privateintid;@Column(name="studentName")privateStringstudentName;@Column(name="studentNo")privateStringstudentNo;@Column(name="sex")privateStringsex;@Column(name="age")privateintage; //以下省略get/set方法}步驟3:修改com.zdsoft.domain包中班級實體類Clazz,添加注解相關配置,關鍵代碼如下:@Entity@Table(name="clazz")publicclassClazz{@Id@GeneratedValue(generator="pkGenerator")@GenericGenerator(name="pkGenerator",strategy="native") privateintid;@Column(name="clazzNo") privateStringclazzNo;@Column(name="clazzName") privateStringclazzName;@Column(name="department") privateStringdepartment;/***一對多關聯映射*targetEntity指定關聯的實體類*JoinColumn指定關聯的實體類對應的數據庫表的外鍵字段名**/@OneToMany(targetEntity=Student.class)@JoinColumn(name="clazz_id")Set<Student>students=newHashSet(0);//以下省略get/set方法}代碼說明:@OneToMany該注解標注實體類中的集合屬性的一對多關系,其targetEntity屬性指定關聯的實體類(多方);@JoinColumn(name=”表外鍵列名”)該注解標注一對多關系中多方實體類對應的數據庫表的外鍵字段名,本例標注集合對象students關聯的實體類為Student,關聯的外鍵字段是實體類Student對應的表student的clazz_id。注:@OneToMany與@JoinColumn一般組合使用。步驟4:修改src下com.zdsoft.dao包中的數據處理類ClazzDao的方法findStudentByClazzId,僅僅修改創建Configuration對象的一句代碼,關鍵代碼如下:publicclassClazzDao{ publicClazzfindStudentByClazzId(intclazzId){ Clazzret=null;//返回值 List<Student>students=newArrayList<Student>(); SessionFactorysessionFactory=null; Configurationcfg=null; Sessionsession=null; try{ cfg=newAnnotationConfiguration();//注解專用 cfg.configure(); sessionFactory=cfg.buildSessionFactory(); session=sessionFactory.openSession(); ret=(Clazz)session.load(Clazz.class,clazzId); }catch(HibernateExceptione){ e.printStackTrace(); } if(session!=null){ session.close(); } if(sessionFactory!=null){ sessionFactory.close(); } returnret; }}步驟5:在hibernate.cfg.xml文件中的session-factory節點中加入實體類:<mappingclass="com.zdsoft.domain.Student"/><mappingclass="com.zdsoft.domain.Clazz"/>去掉或注釋掉對應的映射文件(在hibernate.cfg.xml中去掉下面代碼):<mappingresource="com/zds

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業或盈利用途。
  • 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論