学生成绩管理系统.docx

上传人:b****6 文档编号:15319462 上传时间:2023-07-03 格式:DOCX 页数:20 大小:24KB
下载 相关 举报
学生成绩管理系统.docx_第1页
第1页 / 共20页
学生成绩管理系统.docx_第2页
第2页 / 共20页
学生成绩管理系统.docx_第3页
第3页 / 共20页
学生成绩管理系统.docx_第4页
第4页 / 共20页
学生成绩管理系统.docx_第5页
第5页 / 共20页
学生成绩管理系统.docx_第6页
第6页 / 共20页
学生成绩管理系统.docx_第7页
第7页 / 共20页
学生成绩管理系统.docx_第8页
第8页 / 共20页
学生成绩管理系统.docx_第9页
第9页 / 共20页
学生成绩管理系统.docx_第10页
第10页 / 共20页
学生成绩管理系统.docx_第11页
第11页 / 共20页
学生成绩管理系统.docx_第12页
第12页 / 共20页
学生成绩管理系统.docx_第13页
第13页 / 共20页
学生成绩管理系统.docx_第14页
第14页 / 共20页
学生成绩管理系统.docx_第15页
第15页 / 共20页
学生成绩管理系统.docx_第16页
第16页 / 共20页
学生成绩管理系统.docx_第17页
第17页 / 共20页
学生成绩管理系统.docx_第18页
第18页 / 共20页
学生成绩管理系统.docx_第19页
第19页 / 共20页
学生成绩管理系统.docx_第20页
第20页 / 共20页
亲,该文档总共20页,全部预览完了,如果喜欢就下载吧!
下载资源
资源描述

学生成绩管理系统.docx

《学生成绩管理系统.docx》由会员分享,可在线阅读,更多相关《学生成绩管理系统.docx(20页珍藏版)》请在冰点文库上搜索。

学生成绩管理系统.docx

学生成绩管理系统

Struts2、Spring与Hibernate整合应用

————学生成绩管理系统

要求:

整合Struts2、Spring和Hibernate框架

实现“登录”功能

实现“学生信息管理”功能

实现“学生成绩管理”功能

实现分页功能

目的:

掌握Struts2的开发步骤

掌握Hibernate的开发步骤

掌握Spring的开发步骤,理解依赖注入、AOP、事务管理等

掌握Struts2、Spring和Hibernate框架的整合

掌握分页技术

思路:

建库建表

利用分层思想,建package

添加Spring开发能力

添加Hibernate开发能力

生成Hibernate所需的POJO类和映射文件

开发DAO层

新建DAO层接口。

新建DAO层实现类(该类要实现DAO层接口,继承HibernateDaoSupport类)。

在Spring配置文件中增加该DAO层实现类的定义,并需要依赖注入一个SessionFactorybean的引用。

开发Service层

新建Service层接口。

新建Service层实现类,该类中需要声明所调用DAO层接口,并生其setter方法。

在Spring配置文件中增加该Service层实现类的定义,并需要依赖注入DAO层的bean。

实现WEB层

在web.xml中增加struts2的过滤器和Spring的监听器。

增加Spring和Struts2的整合文件struts.properties。

新建所需的jsp文件。

新建Action类,该类要继承ActionSupport,同时该类要依赖注入Service的bean(声明+setter方法)。

在Spring配置文件中增加该Action类的定义,并注入Service层的bean。

在struts.xml中增加该Action的定义,其中class的属性是在Spring中定义的该Actionbean的id。

9、部署运行

实验步骤:

建库、建表

建立数据库sysDB,建立student_data、login_data、major_data、class_data、score_data等。

学生信息表:

student_data

列名

描述

数据类型

可空

默认值

说明

Stu_No

学号

Char(6)

×

主键

Stu_Name

姓名

Char(8)

×

Stu_Sex

性别

bit

×

1:

男,0:

Stu_BornTime

出生时间

datetime

Stu_Major_ID

专业ID

int

×

Stu_Scores

总学分

int

Stu_Remark

备注

Varchar(200)

Stu_Photo

照片

mediumblob

登录表:

login_data

列名

描述

数据类型

可空

默认值

说明

Log_ID

标识

int

×

自增1

主键,自增

Log_No

登录号

char(6)

×

外键,student_data中Stu_Number

Log_Word

口令

char(20)

×

专业表:

major_data

列名

描述

数据类型

可空

默认值

说明

Maj_ID

ID

int

×

自增1

主键

Maj_Name

专业名

char(12)

×

Maj_Counts

人数

int

0

Maj_Coach

辅导员

char(8)

课程表:

class_data

列名

描述

数据类型

可空

默认值

说明

Cla_NO

课程号

Char(3)

主键

Cla_Name

课程名

Char(12)

 

Cla_Cemester

开课学期

smallint

1-8

Cla_Hour

学时

int

0

 

Cla_Score

学分

int

0

 

 

连接表:

student_class

列名

描述

数据类型

可空

默认值

说明

Stu_NO

学号

char(6)

主键

Cla_NO

课程号

char(3)

主键

成绩表:

score_data

列名

描述

数据类型

可空

默认值

说明

Stu_NO

学号

Char(6)

主键

Cla_NO

课程号

Char(3)

 主键

Score

成绩

int

0

 

Credit

学分

int

0

 

 

设计系统架构

利用分层架构模式,设计系统架构,系统可分为表示层、业务逻辑层和数据持久层。

如下图所示:

建立相应package。

添加Spring开发能力

定义UserLibrary

增加Spring开发能力(添加jar包——使用UserLibrary,新建applicationContext.xml)

注:

可以不增加UserLibrary,直接把需要的jar包拷贝到classpath下。

实现Hibernate持久层

添加Hibernate开发能力

添加jar包:

如果第一步中已增加,此步可以省略。

注意:

需要把Hibernate交由Spring来管理,其中包括在Spring中配置“dataSource”和“sessionFactory”

通过MyEclipse中Hibernate反向工程,分别生成表对应的POJO类及相应的映射文件。

注意:

所有的POJO类和映射文件(*.hbm.xml)放在org.model这个package下。

难点1:

xsb(学生表)的映射文件中需要设置和专业的多对一关系,参考代码如下:

xmlversion="1.0"encoding="utf-8"?

>

DOCTYPEhibernate-mappingPUBLIC"-//Hibernate/HibernateMappingDTD3.0//EN"

"

难点2:

成绩表(cjb)中需要配置复合主键,因为成绩表中的主键是由xh和kch组成,参考代码如下:

xmlversion="1.0"encoding="utf-8"?

>

DOCTYPEhibernate-mappingPUBLIC"-//Hibernate/HibernateMappingDTD3.0//EN"

"

--

MappingfileautogeneratedbyMyEclipsePersistenceTools

-->

--复合主键配置其中两个key-property,分别对应两个主键-->

对应的POJO类由复合主键的POJO类和成绩表的POJO类组成,参考代码如下:

CjbId.java

packageorg.model;

publicclassCjbIdimplementsjava.io.Serializable{

privateStringxh;

privateStringkch;

publicCjbId(){

}

publicCjbId(Stringxh,Stringkch){

this.xh=xh;

this.kch=kch;

}

publicStringgetXh(){

returnthis.xh;

}

publicvoidsetXh(Stringxh){

this.xh=xh;

}

publicStringgetKch(){

returnthis.kch;

}

publicvoidsetKch(Stringkch){

this.kch=kch;

}

}

Cjb.java

packageorg.model;

publicclassCjbimplementsjava.io.Serializable{

privateCjbIdid;

privateIntegercj;

privateIntegerxf;

publicCjb(){

}

publicCjb(CjbIdid){

this.id=id;

}

publicCjb(CjbIdid,Integercj,Integerxf){

this.id=id;

this.cj=cj;

this.xf=xf;

}

publicCjbIdgetId(){

returnthis.id;

}

publicvoidsetId(CjbIdid){

this.id=id;

}

publicIntegergetCj(){

returnthis.cj;

}

publicvoidsetCj(Integercj){

this.cj=cj;

}

publicIntegergetXf(){

returnthis.xf;

}

publicvoidsetXf(Integerxf){

this.xf=xf;

}

}

重点:

所有的映射文件需要在Spring配置文件中注册,参考applicationContext.xml如下:

……

--定义数据库驱动-->

--定义数据库URL-->

mysql:

//localhost:

3306/xscj">

--定义数据库的用户名-->

--定义数据库密码-->

--定义Hibernate的SessionFactory-->

--定义SessionFactory必须注入DataSource-->

--定义Hibernate的SessionFactory属性-->

org.hibernate.dialect.MySQLDialect

--定义POJO的映射文件-->

org/model/Dlb.hbm.xml

org/model/Xsb.hbm.xml

org/model/Kcb.hbm.xml

org/model/Zyb.hbm.xml

org/model/Cjb.hbm.xml

……

实现DAO

所有DAO层的实现类需要继承HibernateDaoSupport类,参考代码如下:

packageorg.dao.imp;

importjava.util.List;

importorg.dao.DlDao;

importorg.model.Dlb;

importorg.springframework.orm.hibernate3.support.HibernateDaoSupport;

publicclassDlDaoImpextendsHibernateDaoSupportimplementsDlDao{

publicbooleanexistXh(Stringxh){

Listlist=getHibernateTemplate().find("fromDlbwherexh=?

",xh);

if(list.size()>0)

returntrue;

else

returnfalse;

}

publicDlbfind(Stringxh,Stringkl){

Stringstr[]={xh,kl};

Listlist=getHibernateTemplate().find("fromDlbwherexh=?

andkl=?

",str);

if(list.size()>0)

return(Dlb)list.get(0);

else

returnnull;

}

publicvoidsave(Dlbuser){

getHibernateTemplate().save(user);

}

}

注意:

所有DAO层的实现类都需要在Spring配置,并且必须获得一个SessionFactory的引用,然后才能完成持久化访问。

换句话说,DAO的实现类都交由Spring容器的Bean来管理。

参考Spring中的配置DAO的部分代码如下“

实现业务逻辑层(Service层)

主要实现对DAO层的调用。

难点1:

依赖注入

依赖注入首先要在需要注入的类中声明一个变量(对象),同时生成该变量(对象)的setter方法。

其次需要在Spring配置文件中设置需要注入的对象。

例如,需要在登录的DlServiceManage类中注入DlDaoImp实例化后的对象,步骤有二:

首先,在DlServiceManage中声明dlDao,同时生成dlDao的setter方法,参考代码如下:

packageorg.service.imp;

importorg.dao.DlDao;

importorg.model.Dlb;

importorg.service.DlService;

publicclassDlServiceManageimplementsDlService{

//对DlDao进行依赖注入

privateDlDaodlDao;

publicvoidsetDlDao(DlDaodlDao){

this.dlDao=dlDao;

}

publicbooleanexistXh(Stringxh){

returndlDao.existXh(xh);

}

publicDlbfind(Stringxh,Stringkl){

returndlDao.find(xh,kl);

}

publicvoidsave(Dlbuser){

dlDao.save(user);

}

}

其次,在Spring的配置文件中进行配置:

对业务逻辑增加事务管理

采用BeanNameAutoProxyCreator,根据BeanName自动生成事务代理的方式。

参考代码:

--HibernateTransactionManagerbean需要依赖注入一个SessionFactorybean的引用-->

--配置事务拦截器-->

--事务拦截器bean需要依赖注入一个事务管理器-->

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 医药卫生 > 预防医学

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2