/**

* controller控制器,用于接收和返回数据,

* 并把接收到的参数传给mapper,调用mapper的方法接口

* 响应用户请求:决定使用什么视图,需要准备什么数据来显示

*/

 

1

spring boot 中分为为 controller层、service层、dao层、entity层。

entity层:entity层和model层一样,存放的是实体类,属性值与数据库中的属性值保持一致。 实现set和get方法。

dao层:即mapper层,对数据库进行持久化操作,他的方法是针对数据库操作的,基本用到的就是增删改查。它只是个接口,只有方法名字,具体实现在mapper.xml中。

service层:业务层,存放业务逻辑处理,不直接对数据库进行操作,有接口和接口实现类,提供controller层调用的方法。

controller层:控制器层,导入service层,调用service

方法,controller通过接收前端传过来的参数进行业务操作,在返回一个指定的路径或者数据表。

controller控制器,用于接收和返回数据,

并把接收到的参数传给mapper,调用mapper的方法接口

2

 

可以这样理解:

controller层-----> service层(接口—>接口实现类) -----> dao层的.mapper文件  -----> 和mapper层里的.xml文件对应

 

Model层是数据层:  TableName是对数据表实体的映射;

                               Criteria传输前台数据

                                DTO 传输类间数据

Mapper层 放置SQL查询XML文件

Dao层相当于XML文件的抽象类

3

 

View层->Controller层(响应用户请求)->Service层(接口->接口实现类)->DAO层,即Mapper层(抽象类:xxxMapper.java文件,具体实现在xxxMapper.xml)->Model层(实体类:xxx.java)

数据层,业务层,控制层

2|0

 

1.view层:       :根据接收的数据,显示给用户浏览(使用模板引擎)

2.controller层    :控制器;@RestController响应用户请求:决定使用什么视图,需要准备什么数据来显示

3.service层    :  

        xxxService.java       接口方法声明;

        xxxServiceImpl.java :接口实现;把 Mapper(与数据库直接打交道)和Service(不直接和数据库打交道)进行整合

                      作用:存放业务逻辑处理,不直接和数据库打交道

                             具有接口和接口的实现方法,在实现类中要倒入mapper

                              提供业务处理的方法

4.Mapper层(即 DAO层):     数据库的CRUD接口,封装对数据库进行数据持久化操作。

                                                   具体的CRUD接口实现在xxxMapper.xml中

5.model层(即entity实体层): 实体类与数据表一一对应。

                                                          提供getter/setter方法,接入数据库。

 

 

3|0VO、DTO、DO、PO理解3|1解释

VO:View Object,视图层,其作用是将指定页面的展示数据封装起来。

DTO:Data Transfer Object,数据传输对象

DO:Domain Object,领域对象

PO:Persistent Object,持久化对象

3|2模型

用户发出请求(填写表单),表单的数据被展示层匹配为VO

展示层把VO转换为服务层对应方法所要求的DTO,提交给服务层

服务层先将DTO的数据构造(或重建)一个DO,调用DO的业务方法完成具体业务

服务层再将DO转换为持久层对应的PO,调用持久层的持久化方法,把PO传递持久化方法,完成持久化操作

4|0PO、VO、BO、DTO、DO、POJO、JavaBean、JavaBeans

PO:持久对象 (persistent object),po(persistent object)就是在Object/Relation Mapping框架中的Entity,po的每个属性基本上都对应数据库表里面的某个字段。完全是一个符合Java Bean规范的纯Java对象,没有增加别的属性和方法。持久对象是由insert数据库创建,由数据库delete删除的。基本上持久对象生命周期和数据库密切相关。

VO: 表现层对象(View Object),主要对应展示界面显示的数据对象,用一个VO对象来封装整个界面展示所需要的对象数据,数据脱敏,去掉用户隐私数据。

BO:业务对象层的缩写(Business Object),封装业务逻辑的java对象,通过调用DAO方法,结合PO,VO进行业务操作。具体可以看网上的一个例子:

比如一个简历,有教育经历、工作经历、社会关系等等。

我们可以把教育经历对应一个PO,工作经历对应一个PO,社会关系对应一个PO。

建立一个对应简历的BO对象处理简历,每个BO包含这些PO。

这样处理业务逻辑时,我们就可以针对BO去处理。

DTO:数据传输对象(Data Transfer Object),是一种设计模式之间传输数据的软件应用系统。数据传输目标往往是数据访问对象从数据库中检索数据。数据传输对象与数据交互对象或数据访问对象之间的差异是一个以不具有任何行为除了存储和检索的数据(访问和存取器)。简单来说,当我们需要一个对象10个字段的内容,但这个对象总共有20个字段,我们不需要把整个PO对象全部字段传输到客户端,而是可以用DTO重新封装,传递到客户端。此时,如果这个对象用来对应界面的展现,就叫VO。

JavaBean:一种可重用组件,即“一次性编写,任何地方执行,任何地方重用”。满足三个条件①类必须是具体的和公共的②具有无参构造器③提供一致性设计模式的公共方法将内部域暴露成员属性。

主要用途:可以用在 功能、处理、值、数据库访问和JSP中任何可以用Java代码创造的对象。

有两种:一种是有用户界面(UI,User Interface)的JavaBean;还有一种是没有用户界面,主要负责处理事务(如数据运算,操纵数据库)的JavaBean。JSP通常访问的是后一种JavaBean。

分类:通常有Session bean,Entity bean,MessageDrivenBean三大类

——Session bean会话构件,是短暂的对象,运行在服务器上,并执行一些应用逻辑处理,它由客户端应用程序建立,其数据需要自己来管理。分为无状态和有状态两种。

——Entity bean实体构件,是持久对象,可以被其他对象调用。在建立时指定一个唯一标示的标识,并允许客户程序,根据实体bean标识来定位beans实例。多个实体可以并发访问实体bean,事务间的协调由容器来完成。

——MessageDriven Bean消息构件,是专门用来处理JMS(Java Message System)消息的规范(EIB2.0)。JMS是一种与厂商无关的API,用来访问消息收发系统,并提供了与厂商无关的访问方法,以此来访问消息收发服务。JMS客户机可以用来发送消息而不必等待回应。

JavaBeans:JavaBeans 从狭义来说,指的是 JavaBeans 规范也就是位于 java.beans 包中的一组 API。从广义上来说,JavaBeans 指的是 API 集合,比如 Enterprise JavaBeans。

POJO:POJO(Plain Ordinary Java Object)简单的Java对象,实际就是普通JavaBeans,是为了避免和EJB混淆所创造的简称。通指没有使用Entity Beans的普通java对象,可以把POJO作为支持业务逻辑的协助类。

POJO实质上可以理解为简单的实体类,顾名思义POJO类的作用是方便程序员使用数据库中的数据表,对于广大的程序员,可以很方便的将POJO类当做对象来进行使用,当然也是可以方便的调用其get,set方法。POJO类也给我们在struts框架中的配置带来了很大的方便。

一个POJO持久化以后就是PO

直接用它传递、传递过程中就是DTO

直接用来对应表示层就是VO

DAO: 数据访问对象是第一个面向对象的数据库接口,是一个数据访问接口(Data Access Object)。它可以把POJO持久化为PO,用PO组装出来VO、DTO。

DAO模式是标准的J2EE设计模式之一.开发人员使用这个模式把底层的数据访问操作和上层的商务逻辑分开.一个典型的DAO实现有下列几个组件:

1. 一个DAO工厂类;

2. 一个DAO接口;

3. 一个实现DAO接口的具体类;

4. 数据传递对象(有些时候叫做值对象).

具体的DAO类包含了从特定的数据源访问数据的逻辑,一般一个DAO类和一张表对应,每个操作要和事务关联。

@Override 的用法

在java中如果方法上加@Override的注解的话,表示子类重写了父类的方法。当然也可以不写,写的好处是:

  1. 可读性提高
  2. 编译器会校验写的方法在父类中是否存在
  1.  

public class Father {

public void test(){

System.out.println("test");

}

class child extends Father{

@Override

public void test(){

}

}

}

如果将test写成test1的话,编译器在父类中未找到此方法,将会报错

 

 

如果将@override注释去掉的话,那么编译器则会认为创建了新的方法

 

 


Logo

瓜分20万奖金 获得内推名额 丰厚实物奖励 易参与易上手

更多推荐