SSM 增删改查

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回显数据。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值