SSM 增删改查
一.简介
SSM中各层作用及关系( SSM中各层作用及关系 - 白云之间 - 博客园 (cnblogs.com) )
1.持久层:DAO层(mapper层)(属于mybatis模块)
- DAO层:主要负责与数据库进行交互设计,用来处理数据的持久化工作。
- DAO层的设计首先是设计DAO的接口,也就是项目中你看到的Dao包。
- 然后在Spring的xml配置文件中定义此接口的实现类,就可在其他模块中调用此接口来进行数据业务的处理,而不用关心接口的具体实现类是哪个类,这里往往用到的就是反射机制,DAO层的jdbc.properties数据源配置,以及有 关数据库连接的参数都在Spring的配置文件中进行配置。
- ps:(有的项目里面Dao层,写成mapper,当成一个意思理解。)
2.业务层:Service层(属于spring模块)
- Service层:主要负责业务模块的逻辑应用设计。也就是项目中你看到的Service包。
- Service层的设计首先是设计接口,再设计其实现的类。也就是项目中你看到的service+impl包。
- 接着再在Spring的xml配置文件中配置其实现的关联。这样我们就可以在应用中调用Service接口来进行业务处理。
- 最后通过调用DAO层已定义的接口,去实现Service具体的实现类。
- ps:(Service层的业务实现,具体要调用到已定义的DAO层的接口.)
3.控制层/表现层:Controller层(Handler层) (属于springMVC模块)
- Controller层:主要负责具体的业务模块流程控制,也就是你看到的controller包。
- Controller层通过要调用Service层的接口来控制业务流程,控制的配置也同样是在Spring的xml配置文件里面,针对具体的业务流程,会有不同的控制器。
4.View层 (属于springMVC模块)
- 负责前台jsp页面的展示,此层需要与Controller层结合起来开发。
- Jsp发送请求,controller接收请求,处理,返回,jsp回显数据。
二:项目分解
参考https://github.com/saysky/SENS/blob/master代码进行分析。
1.实体类:entity:
每一个实体类都对应一张表,里面有数据库中每一章表的赋值,set和get方法:,也可以使用@Data注解
@Data//注解在类上, 为类提供读写属性(提供get/set方法), 此外还提供了 equals()、hashCode()、toString() 方法
2.持久化层:mapper
定义一些数据处理的接口,但是不在这里具体实现,具体的实现是通过xml配置文件中定义此接口的实现类
*/
@Mapper//用于为了把mapper这个DAO交給Spring管理
public interface CheckMapper {
/**
* 根据ID删除
*
* @param id 考勤ID
* @return 影响行数
*/
int deleteById(@Param("id") Long id);
/**
* 添加
*
* @param check 考勤
* @return 影响行数
*/
int insert(Check check);
/**
* 根据ID查询
*
* @param id 考勤ID
* @return 考勤
*/
Check findById(@Param("id") Long id);
/**
* 更新
*
* @param check 考勤
* @return 影响行数
*/
int update(Check check);
/**
* 获得考勤列表
*
* @return 考勤列表
*/
List<Check> findAll();
/**
* 根据姓名模糊查询
* @return
*/
List<Check> findByName(String name);
}
3.Service层
模块的逻辑应用设计,项目中为service+impl包
@Service
public class CheckServiceImpl implements CheckService {
@Autowired
private CheckMapper checkMapper;
@Override
public int deleteById(Long id) {
return checkMapper.deleteById(id);
}
@Override
public int insert(Check check) {
return checkMapper.insert(check);
}
@Override
public Check findById(Long id) {
return checkMapper.findById(id);
}
@Override
public int update(Check check) {
return checkMapper.update(check);
}
@Override
public List<Check> findAll() {
return checkMapper.findAll();
}
@Override
public List<Check> findByName(String name) {
return checkMapper.findByName(name);
}
}
4.Controller层
业务模块流程控制,在Spring的xml配置文件里面进行配置, @Controller用于标记在一个类上,使用它标记的类就是一个SpringMvc Controller对象,分发处理器会扫描使用该注解的类的方法,并检测该方法是否使用了@RequestMapping注解。
@Controller
public class CheckController {
@Autowired
private CheckService checkService;
/**
* 一小时的毫秒数
*/
public static final int HOUR = 1000 * 3600;
/**
* 列表页面
*
* @param model
* @return
*/
@RequestMapping(value = "/check", method = RequestMethod.GET)
public String findAll(@RequestParam(value = "query", required = false) String query, Model model) {
List<Check> checkList;
if (query != null && !"".equals(query)) {
checkList = checkService.findByName(query);
} else {
checkList = checkService.findAll();
}
model.addAttribute("checkList", checkList);
return "check/list";
}
/**
* 添加页面
*
* @return
*/
@RequestMapping(value = "/check/add", method = RequestMethod.GET)
public String add() {
return "check/add";
}
/**
* 编辑页面
*
* @return
*/
@RequestMapping(value = "/check/edit/{id}", method = RequestMethod.GET)
public String add(@PathVariable("id") Long id, Model model) {
Check check = checkService.findById(id);
// 如果不存在,则跳到添加页面
if (check == null) {
return "redirect:/check/add";
}
model.addAttribute("check", check);
return "check/edit";
}
/**
* 保存提交(更新提交或新建提交)
*
* @return
*/
@RequestMapping(value = "/check/save", method = RequestMethod.POST)
public String save(@RequestParam(value = "id", required = false) Long id,
@RequestParam(value = "name") String name,
@RequestParam(value = "age") Integer age,
@RequestParam(value = "number") String number,
@RequestParam(value = "checkInTime") String checkInTime,
@RequestParam(value = "checkOutTime") String checkOutTime) throws ParseException {
Check check = new Check();
check.setAge(age);
check.setName(name);
check.setNumber(number);
SimpleDateFormat simpleDateFormat = new SimpleDateFormat("YYYY-MM-dd'T'HH:mm");
Date checkInDate = simpleDateFormat.parse(checkInTime);
Date checkOutDate = simpleDateFormat.parse(checkOutTime);
check.setCheckInTime(checkInDate);
check.setCheckOutTime(checkOutDate);
double duration = (checkOutDate.getTime() - checkInDate.getTime()) * 1.0 / HOUR;
check.setDuration(duration);
if (id != null) {
check.setId(id);
checkService.update(check);
} else {
checkService.insert(check);
}
return "redirect:/check";
}
/**
* 删除提交
*
* @return
*/
@RequestMapping(value = "/check/delete/{id}", method = RequestMethod.GET)
public String add(@PathVariable("id") Long id) {
checkService.deleteById(id);
return "redirect:/check";
}
5.View层
Jsp发送请求,controller接收请求,处理,返回,jsp回显数据。