首先这是现在最基本的分层方式,结合了SSH架构。modle层就是对应的数据库表的实体类。
Dao层是使用了Hibernate连接数据库、操作数据库(增删改查)。
Service层:引用对应的Dao数据库操作,在这里可以编写自己需要的代码(比如简单的判断)。
Action层:引用对应的Service层,在这里结合Struts的配置文件,跳转到指定的页面,当然也能接受页面传递的请求数据,也可以做些计算处理。
以上的Hibernate,Struts,都需要注入到Spring的配置文件中,Spring把这些联系起来,成为一个整体。
model层
实体类,也就是把数据库表的字段映射为你的对象的各个属性
如你A表有,id,name,password三个属性
你Model里面新建A class
给他 ID,Name,Password三个属性
然后做和数据表字段映射
LINQ TO SQL的时候就会自动读取映射的字段并转换为实体类的属性值
附:代码
import javax.persistence.Column; import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.Id; import javax.persistence.Table; import org.hibernate.annotations.GenericGenerator; @Entity @Table(name = "tab_adminuser") public class AdminUser { private Integer id; private String adminName; private String passwd; @Id @GeneratedValue(generator = "generator") @GenericGenerator(name = "generator", strategy = "native") public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } @Column(length = 200) public String getAdminName() { return adminName; } public void setAdminName(String adminName) { this.adminName = adminName; } @Column(length = 200) public String getPasswd() { return passwd; } public void setPasswd(String passwd) { this.passwd = passwd; } }
Dao层
new一个interface文件
public interface AdminUserDao { public void add(AdminUser user); }
Dao#Impl
new一个class,interface处add Dao文件
import org.hibernate.SessionFactory; public class AdminUserDaoImpl implements AdminUserDao { SessionFactory sessionFactory; public void setSessionFactory(SessionFactory sessionFactory) { this.sessionFactory = sessionFactory; } public void add(AdminUser user) { sessionFactory.getCurrentSession().save(user); } }
Service 的创建和Dao一样,ServiceImpl的创建和DaoImpl一样
ServiceImpl如下:
public class AdminUserServiceImpl implements AdminUserService { AdminUserDao adminUserDao; public void setAdminUserDao(AdminUserDao adminUserDao) { this.adminUserDao = adminUserDao; } public void add(AdminUser user) { adminUserDao.add(user); } }
Controll声明一个Service就后就可以调用Service中的方法,Service调Dao层,Dao操作数据。