<>简介

SSM是sping+springMVC+mybatis集成的框架。

MVC即model view controller。

model层=entity层。存放我们的实体类,与数据库中的属性值基本保持一致。

service层
。存放业务逻辑处理,也是一些关于数据库处理的操作,但不是直接和数据库打交道,他有接口还有接口的实现方法,在接口的实现方法中需要导入mapper层,mapper层是直接跟数据库打交道的,他也是个接口,只有方法名字,具体实现在mapper.xml文件里,service是供我们使用的方法。
service层代码示例:

mapper层=dao层,现在用mybatis逆向工程生成的mapper层,其实就是dao层。

dao层对数据库进行数据持久化操作,他的方法语句是直接针对数据库操作的,而service层是针对我们controller,也就是针对我们使用者。service的impl是把mapper和service进行整合的文件。
dao层代码示例:

数据持久化操作就是指,把数据放到持久化的介质中,同时提供增删改查操作。

dao层和service层关系
:service层经常要调用dao层的方法对数据进行增删改查的操作,现实开发中,对业务的操作会涉及到数据的操作,而对数据操作常常要用到数据库,所以service层会经常调用dao层的方法。

controller层
。控制器,导入service层,因为service中的方法是我们使用到的,controller通过接收前端传过来的参数进行业务操作,在返回一个指定的路径或者数据表。

在实际开发中的Service层可能被处理为实体Service层,而不是接口,业务逻辑直接写在Service(Class,不是Interface)层中,Controller直接调用Service,Service调用Mapper。

Service层是建立在DAO层之上的,建立了DAO层后才可以建立Service层,而Service层又是在Controller层之下的,因而Service层应该既调用DAO层的接口,它刚好处于一个中间层的位置。每个模型都有一个Service接口,每个接口分别封装各自的业务处理方法。

在实际开发中DAO层大多是对某张表进行增删改查,都是一些固定的语句,除非涉及到更复杂的service层业务逻辑,才可能要添加更复杂的DAO层方法。

Controller层一般都是写接口提供给前端或者后端其他服务使用的,一般后端的接口都是写在
Controller层,Controller层的接口里面不写业务逻辑,主要是调用Service层的业务逻辑方法,
service层主要是写业务逻辑方法,service层经常要调用dao层的方法对数据进行增删改查的操作。

当然了,Service之间也是可以互相调用!

<>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); }

技术
下载桌面版
GitHub
Gitee
SourceForge
百度网盘(提取码:draw)
云服务器优惠
华为云优惠券
腾讯云优惠券
阿里云优惠券
Vultr优惠券
站点信息
问题反馈
邮箱:[email protected]
吐槽一下
QQ群:766591547
关注微信