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

下載本文檔

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

文檔簡介

重慶正大軟件學(xué)院軟件系《MVC框架程序設(shè)計(jì)》電子教案重慶正大軟件學(xué)院軟件系《MVC框架程序設(shè)計(jì)》課程組重慶正大軟件職業(yè)技術(shù)學(xué)院教案(項(xiàng)目類)授課對象系別軟件系本次課學(xué)時(shí)4學(xué)時(shí)年級班次大二章節(jié)題目第3章hibernate多對一(注解)目的要求(含技能要求)掌握hibernate注解方式多對一查詢的基本配置本節(jié)重點(diǎn)掌握hibernate注解方式多對一查詢的基本配置本節(jié)難點(diǎn)掌握hibernate注解方式多對一查詢的基本配置教學(xué)方法項(xiàng)目教學(xué)法教學(xué)用具機(jī)房、屏幕廣播問題引入通過用戶注冊案例中出生地的數(shù)據(jù)來源,從而引出本次課程。難點(diǎn)與重點(diǎn)講解方法引導(dǎo)、分析、講解、實(shí)作演示本次課小結(jié)課程小結(jié)教后禮記討論、思考題、作業(yè)(含實(shí)訓(xùn)作業(yè))完成本次課的課堂任務(wù)填寫實(shí)驗(yàn)報(bào)告任務(wù)介紹(5分鐘)改造本章前面查詢注冊信息(實(shí)現(xiàn)多表多對一查詢)任務(wù),要求使用hibernate框架注解方式實(shí)現(xiàn),其表結(jié)構(gòu)省份表(如表3.2-1b所示)、用戶表(如表3.2-1a所示)及查詢頁面(如圖3.2-1c所示)均與本章前面查詢注冊信息(實(shí)現(xiàn)多表多對一查詢)任務(wù)一樣。任務(wù)解析(50-60分鐘)修改省份實(shí)體類Province(增加注解)修改用戶實(shí)體類User(增加注解)修改hibernate.cfg.xml配置文件,添加省份實(shí)體類和用戶實(shí)體類dao層:修改類QueryDao(修改創(chuàng)建Configuration對象代碼)調(diào)試運(yùn)行詳細(xì)步驟修改省份實(shí)體類Province(增加注解)在省份實(shí)體類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;//描述 //以下省略每個(gè)成員變量的get/set方法}修改用戶實(shí)體類User(增加注解)在用戶實(shí)體類User中增加注解,關(guān)鍵代碼如下:@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;@ManyToOne(targetEntity=Clazz.class,fetch=FetchType.EAGER)@JoinColumn(name="province") Provinceprovince; //以下省略每個(gè)成員變量的get/set方法}修改hibernate.cfg.xml配置文件,添加省份實(shí)體類和用戶實(shí)體類在hibernate.cfg.xml配置文件的<session-factory>節(jié)點(diǎn)中添加代碼:<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(修改創(chuàng)建Configuration對象代碼)修改com.zdsoft.dao包下數(shù)據(jù)處理類QueryDao中創(chuàng)建Configuration對象代碼,關(guān)鍵代碼如下:publicclassQueryDao{ //使用hibernate框架創(chuàng)建sessionFactory對象 SessionFactorysessionFactory=newAnnotationConfiguration().configure().buildSessionFactory(); publicList<User>query(Stringprovince){ List<User>ret=null; //編寫查詢的hibernate框架特有的sql語句 Stringhql="fromUserwhere1=1"; if(null!=province&&!"".equals(province)){ hql=hql+"and='"+province+"'"; }else{ returnnull;//若沒有輸入省份,查詢結(jié)果是無意義的,直接返回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; }}調(diào)試運(yùn)行首先,本章3.3節(jié)任務(wù)中service層、action層、sturts配置文件、頁面相關(guān)代碼均可重用,無需修改,然后按照本章3.3節(jié)任務(wù)準(zhǔn)備好查詢的數(shù)據(jù)(如圖3.2-5a、圖3.2-5b所示),然后將工程發(fā)布到服務(wù)器,啟動服務(wù)器,運(yùn)行頁面query.jsp,在查詢條件中輸入重慶,可查到兩條省份為重慶的用戶,如圖3.2-1c所示。根據(jù)任務(wù)提出問題(45-55分鐘)如何使用hibernate注解方式完成多表多對一查詢?問題解析(45-55分鐘)實(shí)現(xiàn)多對一查詢:以學(xué)生信息管理系統(tǒng)根據(jù)班級號查詢學(xué)生信息為例【3.7-1】改造例子3.3-1,使用hibernate注解方式的多對一單向映射實(shí)現(xiàn)查詢功能:根據(jù)班級名稱查詢該班級所有學(xué)生的信息,并把學(xué)生信息列表顯示在查詢頁面中。其學(xué)生表(表3.2-2a)與班級表結(jié)構(gòu)(表3.2-2b)與例子3.3-1一樣。步驟1:在工程src的com.zdsoft.domain包下修改學(xué)生實(shí)體類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;@ManyToOne(cascade={CascadeType.PERSIST,CascadeType.MERGE},targetEntity=Clazz.class,fetch=FetchType.EAGER)@JoinColumn(name="clazz_id") privateClazzclazz; //以下省略get/set方法}代碼說明:@ManyToOne:多對一的注解配置,其中targetEntity屬性指定多對一關(guān)系中“一”方的實(shí)體類。@ManyToOne的cascade屬性指定兩張表的級聯(lián)關(guān)系維護(hù),其取值為——CascadeType.PERSIST:如果一個(gè)實(shí)體是受管狀態(tài),或者當(dāng)persist()函數(shù)被調(diào)用時(shí),觸發(fā)級聯(lián)創(chuàng)建(create)操作;CascadeType.MERGE:如果一個(gè)實(shí)體是受管狀態(tài),或者當(dāng)merge()函數(shù)被調(diào)用時(shí),觸發(fā)級聯(lián)合并(merge)操作;CascadeType.REMOVE:當(dāng)delete()函數(shù)被調(diào)用時(shí),觸發(fā)級聯(lián)刪除(remove)操作;CascadeType.REFRESH:當(dāng)refresh()函數(shù)被調(diào)用時(shí),觸發(fā)級聯(lián)更新(refresh)操作;CascadeType.ALL:以上全部。該屬性可以指定零到多個(gè)值。本例指定了增加和修改操作的級聯(lián),那么在使用hibernate框架在學(xué)生表中增加或修改數(shù)據(jù)時(shí),班級表中數(shù)據(jù)也會同步進(jìn)行增加或修改。不過,該屬性并非必須項(xiàng),讀者也可以通過外鍵,將級聯(lián)關(guān)系的處理交給數(shù)據(jù)庫來維護(hù)。@ManyToOne的fetch屬性指定在查詢數(shù)據(jù)(獲取數(shù)據(jù))中是否使用懶加載,其取值可以設(shè)置為FetchType.LAZY(使用懶加載)或者FetchType.EAGER(不使用懶加載)。本例指定不使用懶加載。@JoinColumn:指定多對一關(guān)系中“多”方表的外鍵字段名(不是“多”方實(shí)體類中的成員變量),本例是學(xué)生表student中的clazz_id。步驟2:在com.zdsoft.domain包下修改班級實(shí)體類Clazz,加入注解,關(guān)鍵代碼如下:@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;//以下省略get/set方法}步驟3:在com.zdsoft.dao包下修改ClazzDao,僅僅修改創(chuàng)建Configuration對象的一句代碼,關(guān)鍵代碼如下:publicclassClazzDao{ //使用hibernate框架注解方式創(chuàng)建sessionFactory對象 SessionFactorysessionFactory=newAnnotationConfiguration().configure().buildSessionFactory(); publicList<Student>findStudentByClazzId(StringclazzName){ List<Student>ret=null; //編寫查詢的hibernate框架特有的sql語句 Stringhql="fromStudentwhereclazz.clazzName='"+clazzName+"'"; Sessionsession=sessionFactory.openSession(); try{ Queryquery=session.createQuery(hql); ret=query.list(); }catch(HibernateExceptione){ e.printS

溫馨提示

  • 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)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論