




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
重慶正大軟件學(xué)院軟件系《MVC框架程序設(shè)計(jì)》電子教案重慶正大軟件學(xué)院軟件系《MVC框架程序設(shè)計(jì)》課程組重慶正大軟件職業(yè)技術(shù)學(xué)院教案(項(xiàng)目類)授課對(duì)象系別軟件系本次課學(xué)時(shí)4學(xué)時(shí)年級(jí)班次大二章節(jié)題目第3章hibernate一對(duì)多(注解)目的要求(含技能要求)掌握hibernate注解方式一對(duì)多查詢的基本配置本節(jié)重點(diǎn)掌握hibernate注解方式一對(duì)多查詢的基本配置本節(jié)難點(diǎn)掌握hibernate注解方式一對(duì)多查詢的基本配置教學(xué)方法項(xiàng)目教學(xué)法教學(xué)用具機(jī)房、屏幕廣播問題引入通過用戶注冊(cè)案例中出生地的數(shù)據(jù)來(lái)源,從而引出本次課程。難點(diǎn)與重點(diǎn)講解方法引導(dǎo)、分析、講解、實(shí)作演示本次課小結(jié)課程小結(jié)教后禮記討論、思考題、作業(yè)(含實(shí)訓(xùn)作業(yè))完成本次課的課堂任務(wù)填寫實(shí)驗(yàn)報(bào)告任務(wù)介紹(5分鐘)改造本章查詢注冊(cè)信息(實(shí)現(xiàn)多表一對(duì)多查詢)任務(wù),使用hibernate注解方式完成,其表結(jié)構(gòu)(如表3.2-1a、表3.2-1b所示)、頁(yè)面(如圖3.2-1c所示)均與查詢注冊(cè)信息(實(shí)現(xiàn)多表一對(duì)多查詢)任務(wù)一樣。任務(wù)解析(50-60分鐘)修改省份實(shí)體類Province(增加注解)修改用戶實(shí)體類User(增加注解)修改hibernate.cfg.xml配置文件,添加省份實(shí)體類和用戶實(shí)體類dao層:修改類QueryDao(修改創(chuàng)建Configuration對(duì)象代碼)調(diào)試運(yùn)行詳細(xì)步驟修改省份實(shí)體類Province(增加注解)修改工程的com.zdsoft.domain包下省份實(shí)體類Province,加入注解,關(guān)鍵代碼如下:@Entity@Table(name="province")publicclassProvince{@Id@GeneratedValue(generator="pkGenerator")@GenericGenerator(name="pkGenerator",strategy="native") intid;//省份流水號(hào)@Column(name="name") Stringname;//省份名稱@Column(name="note") Stringnote;//描述@OneToMany(targetEntity=User.class)@JoinColumn(name="province") privateSet<User>users=newHashSet(0);//同一個(gè)省份的多個(gè)用戶 //以下省略每個(gè)成員變量的get/set方法}修改用戶實(shí)體類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; //以下省略每個(gè)成員變量的get/set方法}修改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對(duì)象代碼)在com.zdsoft.dao包下數(shù)據(jù)處理類QueryDao中修改創(chuàng)建Configuration對(duì)象代碼,關(guān)鍵代碼如下:publicclassQueryDao{ //使用hibernate框架注解方式創(chuàng)建sessionFactory對(duì)象 SessionFactorysessionFactory=newAnnotationConfiguration().configure().buildSessionFactory(); publicList<Province>query(Stringprovince){ List<Province>ret=null; //編寫查詢的hibernate框架特有的sql語(yǔ)句 Stringhql="fromProvincewhere1=1"; if(null!=province&&!"".equals(province)){ hql=hql+"andname='"+province+"'"; }else{ returnnull;//若沒有輸入省份,查詢結(jié)果是無(wú)意義的,直接返回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.2節(jié)任務(wù)中service層、action層、sturts配置文件、頁(yè)面相關(guān)代碼均可重用,無(wú)需修改,然后按照本章3.2節(jié)任務(wù)準(zhǔn)備好查詢的數(shù)據(jù)(如圖3.2-5a、圖3.2-5b所示),然后將工程發(fā)布到服務(wù)器,啟動(dòng)服務(wù)器,運(yùn)行頁(yè)面query.jsp,在查詢條件中輸入重慶,可查到兩條省份為重慶的用戶,如圖3.2-1c所示。根據(jù)任務(wù)提出問題(45-55分鐘)如何使用hibernate注解方式完成多表一對(duì)多查詢?問題解析(45-55分鐘)如何使用hibernate注解方式完成多表一對(duì)多查詢?實(shí)現(xiàn)一對(duì)多查詢:以學(xué)生信息管理系統(tǒng)根據(jù)班級(jí)號(hào)查詢學(xué)生信息為例。【例子3.6-1】改造例子3.2-1,以注解方式實(shí)現(xiàn)根據(jù)班級(jí)id查詢?cè)摪嗉?jí)所有學(xué)生的信息,并把學(xué)生信息列表顯示在查詢頁(yè)面中的功能。本例子的頁(yè)面(如圖3.2-4d)、數(shù)據(jù)庫(kù)表(表結(jié)構(gòu)如表3.2-2a、表3.2-2b所示)均與3.2-1一樣。步驟1:在eclipse中創(chuàng)建web工程studentInfoManage,并把hibernate,struts2及數(shù)據(jù)庫(kù)所需的jar包拷貝到工程WebContent/WEB-INF/lib目錄下。步驟2:修改com.zdsoft.domain包中的學(xué)生實(shí)體類Student,添加注解相關(guān)配置,該代碼沒有一對(duì)多的配置,關(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包中班級(jí)實(shí)體類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;/***一對(duì)多關(guān)聯(lián)映射*targetEntity指定關(guān)聯(lián)的實(shí)體類*JoinColumn指定關(guān)聯(lián)的實(shí)體類對(duì)應(yīng)的數(shù)據(jù)庫(kù)表的外鍵字段名**/@OneToMany(targetEntity=Student.class)@JoinColumn(name="clazz_id")Set<Student>students=newHashSet(0);//以下省略get/set方法}代碼說明:@OneToMany該注解標(biāo)注實(shí)體類中的集合屬性的一對(duì)多關(guān)系,其targetEntity屬性指定關(guān)聯(lián)的實(shí)體類(多方);@JoinColumn(name=”表外鍵列名”)該注解標(biāo)注一對(duì)多關(guān)系中多方實(shí)體類對(duì)應(yīng)的數(shù)據(jù)庫(kù)表的外鍵字段名,本例標(biāo)注集合對(duì)象students關(guān)聯(lián)的實(shí)體類為Student,關(guān)聯(lián)的外鍵字段是實(shí)體類Student對(duì)應(yīng)的表student的clazz_id。注:@OneToMany與@JoinColumn一般組合使用。步驟4:修改src下com.zdsoft.dao包中的數(shù)據(jù)處理類ClazzDao的方法findStudentByClazzId,僅僅修改創(chuàng)建Configuration對(duì)象的一句代碼,關(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é)點(diǎn)中加入實(shí)體類:<mappingclass="com.zdsoft.domain.Student"/><mappingclass="com.zdsoft.domain.Clazz"/>去掉或注釋掉對(duì)應(yīng)的映射文件(在hibernate.cfg.xml中去掉下面代碼):<mappingresource="com/zds
溫馨提示
- 1. 本站所有資源如無(wú)特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 氣管腫瘤術(shù)后護(hù)理規(guī)范與要點(diǎn)
- 原地單手肩上投籃
- 勞動(dòng)教育實(shí)施路徑與實(shí)踐創(chuàng)新
- 中華護(hù)理學(xué)會(huì)介紹
- 呼吸內(nèi)科創(chuàng)建簡(jiǎn)介
- 采購(gòu)招標(biāo)法律法規(guī)
- 購(gòu)物中心教育培訓(xùn)商業(yè)化探索
- 手術(shù)室胃切除護(hù)理查房
- 子癇前期重度術(shù)后護(hù)理
- 2025年零售門店數(shù)字化技術(shù)應(yīng)用在顧客互動(dòng)營(yíng)銷中的策略報(bào)告
- DZ∕T 0388-2021 礦區(qū)地下水監(jiān)測(cè)規(guī)范(正式版)
- 腦干損傷護(hù)理常規(guī)
- 機(jī)動(dòng)車安全技術(shù)檢驗(yàn)操作規(guī)范標(biāo)準(zhǔn)
- MOOC 數(shù)值天氣預(yù)報(bào)-南京信息工程大學(xué) 中國(guó)大學(xué)慕課答案
- 跨座式單軌交通工程接觸網(wǎng)系統(tǒng)技術(shù)標(biāo)準(zhǔn)
- 教師口語(yǔ)智慧樹知到期末考試答案2024年
- 從乙醇的結(jié)構(gòu)看其發(fā)生化學(xué)反應(yīng)時(shí)鍵的斷裂位置和方式
- 2024年江西贛州旅游投資集團(tuán)限公司招聘13人高頻考題難、易錯(cuò)點(diǎn)模擬試題(共500題)附帶答案詳解
- 小學(xué)信息技術(shù)所有知識(shí)點(diǎn)大匯總(最全)
- 好老師是民族的希望
- 項(xiàng)目建設(shè)審批流程課件
評(píng)論
0/150
提交評(píng)論