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

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

重慶正大軟件學(xué)院軟件系《MVC框架程序設(shè)計》電子教案重慶正大軟件學(xué)院軟件系《MVC框架程序設(shè)計》課程組重慶正大軟件職業(yè)技術(shù)學(xué)院教案(項目類)授課對象系別軟件系本次課學(xué)時4學(xué)時年級班次大二章節(jié)題目第3章hibernate多對多(注解)目的要求(含技能要求)掌握hibernate注解方式多對多查詢的基本配置本節(jié)重點掌握hibernate注解方式多對多查詢的基本配置本節(jié)難點掌握hibernate注解方式多對多查詢的基本配置教學(xué)方法項目教學(xué)法教學(xué)用具機(jī)房、屏幕廣播問題引入通過用戶注冊案例中的數(shù)據(jù)入庫,從而引出本次課程。難點與重點講解方法引導(dǎo)、分析、講解、實作演示本次課小結(jié)課程小結(jié)教后禮記討論、思考題、作業(yè)(含實訓(xùn)作業(yè))完成本次課的課堂任務(wù)填寫實驗報告任務(wù)介紹(5分鐘)改造本章前面查詢注冊信息(實現(xiàn)多表多對多查詢)任務(wù),要求使用hibernate框架注解方式實現(xiàn),其表結(jié)構(gòu)愛好表(如表3.4-3a所示)、用戶表(如表3.4-3b所示)及查詢頁面(如圖3.4-3c所示)均與本章前面查詢注冊信息(實現(xiàn)多表多對多查詢)任務(wù)一樣。任務(wù)解析(50-60分鐘)修改愛好實體類Hobby(加入注解)修改用戶實體類User(加入注解)修改hibernate.cfg.xml配置文件,加入用戶、愛好實體類配置dao層:修改類QueryDao(修改創(chuàng)建Configuration對象代碼)調(diào)試運行詳細(xì)步驟修改愛好實體類Hobby(加入注解)在愛好實體類Hobby中增加注解,關(guān)鍵代碼如下:@Entity@Table(name="province")publicclassHobby{@Id@GeneratedValue(generator="pkGenerator")@GenericGenerator(name="pkGenerator",strategy="native") privateintid;@Column(name="name") privateStringname;@Column(name="note") privateStringnote; @ManyToMany(targetEntity=User.class,fetch=FetchType.EAGER) @JoinTable(name="user_hobby",joinColumns={@JoinColumn(name="hobby_id")},inverseJoinColumns={@JoinColumn(name="user_id")}) Set<User>users=newHashSet(0); //以下省略get/set方法}修改用戶實體類User(加入注解)在用戶實體類User中增加注解,關(guān)鍵代碼如下:@Entity@Table(name="user")publicclassUser{ @Id @GeneratedValue(generator="pkGenerator") @GenericGenerator(name="pkGenerator",strategy="native") intid; @Column(name="courseName") Stringname; @Column(name="courseName") StringuserName; @Column(name="courseName") Stringpassword; @Column(name="courseName") Stringsex; @Column(name="courseName") intage; @Column(name="courseName") Datebirth; @Column(name="courseName") Stringmobile; @Column(name="courseName") Stringemail;@ManyToOne(targetEntity=Clazz.class,fetch=FetchType.EAGER)@JoinColumn(name="province") Provinceprovince; //以下省略每個成員變量的get/set方法}上述代碼中涉及到用戶與省份的多對一關(guān)系,因此,還要在省份實體類中加入注解。其省份實體類Province的關(guān)鍵代碼如下:@Entity@Table(name="province")publicclassProvince{@Id@GeneratedValue(generator="pkGenerator")@GenericGenerator(name="pkGenerator",strategy="native") intid;//省份流水號@Column(name="name") Stringname;//省份名稱@Column(name="note") Stringnote;//描述 //以下省略每個成員變量的get/set方法}修改hibernate.cfg.xml配置文件,加入用戶、愛好實體類配置在hibernate.cfg.xml配置文件的<session-factory>節(jié)點中添加代碼:<mappingclass="com.zdsoft.domain.Hobby"/><mappingclass="com.zdsoft.domain.User"/><mappingclass="com.zdsoft.domain.Province"/>在hibernate.cfg.xml配置文件的<session-factory>節(jié)點中去掉或注釋以下代碼:<mappingresource="com/zdsoft/domain/Hobby.hbm.xml"/><mappingresource="com/zdsoft/domain/User.hbm.xml"/><mappingresource="com/zdsoft/domain/Province.hbm.xml"/>dao層:修改類QueryDao(修改創(chuàng)建Configuration對象代碼)修改com.zdsoft.dao包下數(shù)據(jù)處理類QueryDao中創(chuàng)建Configuration對象代碼,關(guān)鍵代碼如下:publicclassQueryDao{ //使用hibernate框架創(chuàng)建sessionFactory對象 SessionFactorysessionFactory=newAnnotationConfiguration().configure().buildSessionFactory(); publicHobbyquery(Stringname){ Hobbyret=null; //編寫查詢的hibernate框架特有的sql語句 if(name==null||"".equals(name)){ returnnull;//若不輸入查詢條件愛好,該查詢結(jié)果無意義,直接返回null } Stringhql="fromHobbywherename='"+name+"'"; Sessionsession=sessionFactory.openSession(); try{ Queryquery=session.createQuery(hql); ret=(Hobby)query.list().get(0);//返回的結(jié)果應(yīng)該是一條記錄 }catch(HibernateExceptione){ e.printStackTrace(); ret=null; }finally{ if(session!=null){ session.close(); } } returnret; }}調(diào)試運行首先,本章3.4節(jié)任務(wù)中service層、action層、sturts配置文件、頁面相關(guān)代碼均可重用,無需修改,然后按照本章3.4節(jié)任務(wù)準(zhǔn)備好查詢的數(shù)據(jù)(如圖3.4-3e、圖3.4-3f、3.4-3g所示),然后將工程發(fā)布到服務(wù)器,啟動服務(wù)器,運行頁面query.jsp,最后輸入查詢條件——打乒乓,查詢結(jié)果與3.4節(jié)一樣(如圖3.4-3c所示)。根據(jù)任務(wù)提出問題(45-55分鐘)如何使用hibernate注解方式完成多表多對多查詢?問題解析(45-55分鐘)使用hibernate注解方式完成多表多對多查詢這里以學(xué)生信息管理系統(tǒng)查詢學(xué)生選課信息為例來說明。【例子3.8-1】改造例子3.4-1,使用hibernate注解方式實現(xiàn)根據(jù)課程名稱查詢選修該課程的所有學(xué)生信息的查詢功能。查詢的學(xué)生表(如表3.4-1a)、課程表(如表3.4-1b)、學(xué)生選課表(如表3.4-1c)均與例子3.4-1一樣。步驟1:修改com.zdsoft.domain包下學(xué)生實體類Student,加入注解,關(guān)鍵代碼如下:@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方法}步驟2:修改com.zdsoft.domain包下課程實體類Course,加入注解,關(guān)鍵代碼如下:@Entity@Table(name="course")publicclassCourse{@Id@GeneratedValue(generator="pkGenerator")@GenericGenerator(name="pkGenerator",strategy="native") privateintid;@Column(name="courseName") privateStringcourseName;@Column(name="courseNo") privateStringcourseNo;@Column(name="courseType") privateStringcourseType;@Column(name="credit") privateintcredit; @ManyToMany(targetEntity=Student.class,fetch=FetchType.EAGER) @JoinTable(name="student_course",joinColumns={@JoinColumn(name="course_id")},inverseJoinColumns={@JoinColumn(name="student_id")}) privateSet<Student>students=newHashSet(0); //以下省略get/set方法}代碼說明:@ManyToMany進(jìn)行一個多對多的關(guān)聯(lián)。其屬性targetEntity指定多對多關(guān)系中另外一個“多”方的實體類,fetch屬性指定是否懶加載,本例是課程實體類與學(xué)生實體類Student為多對多關(guān)系,fetch=FetchType.EAGER表示不使用懶加載。@JoinTable描述多對多產(chǎn)關(guān)系的中間表。其屬性name是指定中間表名,本例中間表名是student_course.@JoinTable中的joinColumns屬性描述中間表與多對多關(guān)系中本代碼所在的這個“多”方之間的外鍵關(guān)系,其中嵌套注解@JoinColumn指定中間表的一個外鍵,該外鍵與本代碼所在實體類所對應(yīng)的表相關(guān)聯(lián)。本例注解@JoinColum所在的實體類是課程Course,對應(yīng)的表是course,與中間表student_course關(guān)聯(lián)的外鍵是course_id.@JoinTable中的inverseJoinColumns描述中間表與多對多關(guān)系中另一方(本代碼所注解的集合成員變量類型)的外鍵關(guān)系,其中嵌套注解@JoinColumn指定中間表的另一個外鍵,該外鍵與另一方實體類所對應(yīng)的表相關(guān)聯(lián)。本例指定的另一方(本代碼所注解的集合成員變量類型)是學(xué)生實體類Student,對應(yīng)的表是student,與中間表student_course關(guān)聯(lián)的外鍵是student_id.步驟3:在hibernate.cfg.xml文件中的session-factory節(jié)點中加入實體類:<mappingclass="com.zdsoft.domain.Student"/><mappingclass="com.zdsoft.domain.Course"/>在hibernate.cfg.xml文件中的session-factory節(jié)點中去掉實體類的映射文件:<mappingresource="com/zdsoft/domain/Student.hbm.xml"/><mappingresource="com/zdsoft/domain/Course.hbm.xml"/>步驟4:修改com.zdsoft.dao包下數(shù)據(jù)處理類QueryDao中創(chuàng)建Configuration對象的一句代碼,關(guān)鍵代碼如下:publicclassQueryDao{ //使用hibernate框架創(chuàng)建sessionFactory對象 SessionFactorysessionFactory=newAnnotationConfiguration().configure().buildSessionFactory(); publicCoursefindStudentByCourseName(StringcourseName){ Courseret

溫馨提示

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

評論

0/150

提交評論