解析Java框架中entity层,mapper层,service层,controller各层作用

    xiaoxiao2022-07-04  141

    一、entity层

    别名: model层 ,domain层 用途: 实体层,用于存放我们的实体类,与数据库中的属性值基本保持一致,实现set和get的方法。 例子:user表的实体User

    public class User { /** * 用户id */ @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; /** * 用户昵称 */ private String nick; /** * 手机号 */ private String mobile; /** * 头像地址 */ @Column(name = "head_image_url") private String headImageUrl; /** * 获取用户id * * @return id - 用户id */ public Long getId() { return id; } /** * 设置用户id * * @param id 用户id */ public void setId(Long id) { this.id = id; } /** * 获取用户昵称 * * @return nick - 用户昵称 */ public String getNick() { return nick; } /** * 设置用户昵称 * * @param nick 用户昵称 */ public void setNick(String nick) { this.nick = nick; } /** * 获取手机号 * * @return mobile - 手机号 */ public String getMobile() { return mobile; } /** * 设置手机号 * * @param mobile 手机号 */ public void setMobile(String mobile) { this.mobile = mobile; } /** * 获取头像地址 * * @return head_image_url - 头像地址 */ public String getHeadImageUrl() { return headImageUrl; } /** * 设置头像地址 * * @param headImageUrl 头像地址 */ public void setHeadImageUrl(String headImageUrl) { this.headImageUrl = headImageUrl; } }

    二、mapper层

    别名: dao层 用途: 对数据库进行数据持久化操作,他的方法语句是直接针对数据库操作的,主要实现一些增删改查操作,在mybatis中方法主要与与xxx.xml内相互一一映射。 示例:userMapper

    public interface userMapper { int deleteByPrimaryKey(Long id); int insert(user record); int insertSelective(user record); user selectByPrimaryKey(Long id); int updateByPrimaryKeySelective(user record); int updateByPrimaryKey(user record); }

    三、service层

    用途:业务service层,给controller层的类提供接口进行调用。一般就是自己写的方法封装起来,就是声明一下,具体实现在serviceImpl中。 示例:UserService

    public interface UserService extends Service<User> { }

    四、controller层

    别名:web 层 用途: 控制层,负责具体模块的业务流程控制,需要调用service逻辑设计层的接口来控制业务流程。因为service中的方法是我们使用到的,controller通过接收前端H5或者App传过来的参数进行业务操作,再将处理结果返回到前端。 示例:UserController

    @RestController @RequestMapping("/user") public class UserController { @Resource private UserService userService; @PostMapping("/add") public Result add(User user) { userService.save(user); return ResultGenerator.genSuccessResult(); } @PostMapping("/delete") public Result delete(@RequestParam Integer id) { userService.deleteById(id); return ResultGenerator.genSuccessResult(); } @PostMapping("/update") public Result update(User user) { userService.update(user); return ResultGenerator.genSuccessResult(); } @PostMapping("/detail") public Result detail(@RequestParam Integer id) { User user = userService.findById(id); return ResultGenerator.genSuccessResult(user); } @PostMapping("/list") public Result list(@RequestParam(defaultValue = "0") Integer page, @RequestParam(defaultValue = "0") Integer size) { PageHelper.startPage(page, size); List<User> list = userService.findAll(); PageInfo pageInfo = new PageInfo(list); return ResultGenerator.genSuccessResult(pageInfo); } }

    转载自 https://blog.csdn.net/u011095110/article/details/86088976

    最新回复(0)