




版權(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é)用具機房、屏幕廣播問題引入通過用戶注冊案例中出生地的數(shù)據(jù)來源,從而引出本次課程。難點與重點講解方法引導(dǎo)、分析、講解、實作演示本次課小結(jié)課程小結(jié)教后禮記討論、思考題、作業(yè)(含實訓(xùn)作業(yè))完成本次課的課堂任務(wù)填寫實驗報告任務(wù)介紹(5分鐘)改造本章查詢注冊信息(實現(xiàn)多表一對多查詢)任務(wù),使用hibernate注解方式完成,其表結(jié)構(gòu)(如表3.2-1a、表3.2-1b所示)、頁面(如圖3.2-1c所示)均與查詢注冊信息(實現(xiàn)多表一對多查詢)任務(wù)一樣。任務(wù)解析(50-60分鐘)修改省份實體類Province(增加注解)修改用戶實體類User(增加注解)修改hibernate.cfg.xml配置文件,添加省份實體類和用戶實體類dao層:修改類QueryDao(修改創(chuàng)建Configuration對象代碼)調(diào)試運行詳細(xì)步驟修改省份實體類Province(增加注解)修改工程的com.zdsoft.domain包下省份實體類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;//描述@OneToMany(targetEntity=User.class)@JoinColumn(name="province") privateSet<User>users=newHashSet(0);//同一個省份的多個用戶 //以下省略每個成員變量的get/set方法}修改用戶實體類User(增加注解)修改com.zdsoft.domain包下的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; //以下省略每個成員變量的get/set方法}修改hibernate.cfg.xml配置文件,在<session-factory>節(jié)點中添加代碼:<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<Province>query(Stringprovince){ List<Province>ret=null; //編寫查詢的hibernate框架特有的sql語句 Stringhql="fromProvincewhere1=1"; if(null!=province&&!"".equals(province)){ hql=hql+"andname='"+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)試運行首先,本章3.2節(jié)任務(wù)中service層、action層、sturts配置文件、頁面相關(guān)代碼均可重用,無需修改,然后按照本章3.2節(jié)任務(wù)準(zhǔn)備好查詢的數(shù)據(jù)(如圖3.2-5a、圖3.2-5b所示),然后將工程發(fā)布到服務(wù)器,啟動服務(wù)器,運行頁面query.jsp,在查詢條件中輸入重慶,可查到兩條省份為重慶的用戶,如圖3.2-1c所示。根據(jù)任務(wù)提出問題(45-55分鐘)如何使用hibernate注解方式完成多表一對多查詢?問題解析(45-55分鐘)如何使用hibernate注解方式完成多表一對多查詢?實現(xiàn)一對多查詢:以學(xué)生信息管理系統(tǒng)根據(jù)班級號查詢學(xué)生信息為例?!纠?.6-1】改造例子3.2-1,以注解方式實現(xiàn)根據(jù)班級id查詢該班級所有學(xué)生的信息,并把學(xué)生信息列表顯示在查詢頁面中的功能。本例子的頁面(如圖3.2-4d)、數(shù)據(jù)庫表(表結(jié)構(gòu)如表3.2-2a、表3.2-2b所示)均與3.2-1一樣。步驟1:在eclipse中創(chuàng)建web工程studentInfoManage,并把hibernate,struts2及數(shù)據(jù)庫所需的jar包拷貝到工程WebContent/WEB-INF/lib目錄下。步驟2:修改com.zdsoft.domain包中的學(xué)生實體類Student,添加注解相關(guān)配置,該代碼沒有一對多的配置,關(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方法}步驟3:修改com.zdsoft.domain包中班級實體類Clazz,添加注解相關(guān)配置,關(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;/***一對多關(guān)聯(lián)映射*targetEntity指定關(guān)聯(lián)的實體類*JoinColumn指定關(guān)聯(lián)的實體類對應(yīng)的數(shù)據(jù)庫表的外鍵字段名**/@OneToMany(targetEntity=Student.class)@JoinColumn(name="clazz_id")Set<Student>students=newHashSet(0);//以下省略get/set方法}代碼說明:@OneToMany該注解標(biāo)注實體類中的集合屬性的一對多關(guān)系,其targetEntity屬性指定關(guān)聯(lián)的實體類(多方);@JoinColumn(name=”表外鍵列名”)該注解標(biāo)注一對多關(guān)系中多方實體類對應(yīng)的數(shù)據(jù)庫表的外鍵字段名,本例標(biāo)注集合對象students關(guān)聯(lián)的實體類為Student,關(guān)聯(lián)的外鍵字段是實體類Student對應(yīng)的表student的clazz_id。注:@OneToMany與@JoinColumn一般組合使用。步驟4:修改src下com.zdsoft.dao包中的數(shù)據(jù)處理類ClazzDao的方法findStudentByClazzId,僅僅修改創(chuàng)建Configuration對象的一句代碼,關(guān)鍵代碼如下: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節(jié)點中加入實體類:<mappingclass="com.zdsoft.domain.Student"/><mappingclass="com.zdsoft.domain.Clazz"/>去掉或注釋掉對應(yīng)的映射文件(在hibernate.cfg.xml中去掉下面代碼):<mappingresource="com/zds
溫馨提示
- 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)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 醫(yī)藥電商平臺藥品供應(yīng)鏈金融與合規(guī)風(fēng)險管理報告
- 2025年生物質(zhì)能源分布式能源系統(tǒng)能源效率與環(huán)保標(biāo)準(zhǔn)優(yōu)化報告
- 金融科技行業(yè)估值方法與投資策略研究報告-2025年展望
- 現(xiàn)場演藝市場復(fù)蘇2025年虛擬現(xiàn)實演出形式研究報告001
- 2025年基層醫(yī)療衛(wèi)生機構(gòu)信息化建設(shè)中的醫(yī)療信息化與醫(yī)療服務(wù)互聯(lián)網(wǎng)化監(jiān)管體系報告
- 交通設(shè)備制造業(yè)數(shù)字化轉(zhuǎn)型與智能生產(chǎn)質(zhì)量保障報告
- 安全主管試題及答案
- 安全責(zé)任試題及答案
- 區(qū)塊鏈技術(shù)驅(qū)動2025年數(shù)字貨幣在金融領(lǐng)域應(yīng)用與風(fēng)險控制報告
- 安全試題單選竅門及答案
- 腰椎椎管狹窄癥治療的新方法課件
- 完工付款最終付款申請表
- 有限空間作業(yè)及應(yīng)急物資清單
- 人工動靜脈內(nèi)瘺
- 國際經(jīng)濟學(xué)期末考試試題庫含答案
- 慢阻肺隨訪記錄表正式版
- 基于PLC的音樂噴泉控制系統(tǒng)的設(shè)計-畢業(yè)設(shè)計
- 體育場地與設(shè)施
- 廣西大學(xué)數(shù)學(xué)建模競賽選拔賽題目
- 受戒申請表(共3頁)
- 五年級部編版語文下學(xué)期修改病句專項強化練習(xí)題
評論
0/150
提交評論