DAO层,Service层,Controller层的作用

DAO层,Service层,Controller层的作用

转载自violet_evgr的DAO层,Service层,Controller层的作用


DAO层:

DAO层主要是做数据持久层的工作,用来对应数据库实体,负责与数据库进行联络的一些任务都封装在此。主要就是封装一些数据库的增删改查操作,但仅仅是封装了操作,具体的实现并不在dao层里,所以我们可以看到日常的dao层都是以接口形式实现,里面写的方法也都是交给业务层也就是service层去调用。这样的话就实现了高度的解耦合,这样我们的service层就可以专注于实现业务逻辑,而不需要跟数据库产生任何关系,只要跟数据库相关的操作我们都在dao层进行定义就完事了,service层只是去调用dao层里写的方法。DAO层的设计首先是设计DAO的接口,然后在Spring的配置文件中定义此接口的实现类,然后就可在模块中调用此接口来进行数据业务的处理,而不用关心此接口的具体实现类是哪个类,显得结构非常清晰,DAO层的数据源配置,以及有关数据库连接的参数都在Spring的配置文件中进行配置。

Service层:

Service层主要负责业务模块的逻辑。一般service层我们会先写一个interface,这个接口以service为后缀表示这是一个service接口,在这个类里定义好我们需要的方法,然后写实现类去实现这个接口里的方法,这样可以做到高度解耦合,非常nice的编程习惯。service层编写完成后,我们就可以在controller层中调用Service接口来进行业务处理。Service层的业务实现,具体要调用到已定义的DAO层的接口,封装Service层的业务逻辑有利于通用的业务逻辑的独立性和重复利用性,程序显得非常简洁。

Controller层:

Controller层负责具体的业务模块流程的控制,就是我们进行编程时候以Api为后缀结尾的类,在此层里面要调用Serice层的接口来控制业务流程,因为service层里封装了业务处理的方法。控制器主要就是来调用这些service来实现业务。针对具体的业务流程,会有不同的控制器,我们具体的设计过程中可以将流程进行抽象归纳,设计出可以重复利用的子单元流程模块,这样不仅使程序结构变得清晰,也大大减少了代码量。

你可能感兴趣的:(spring,java,后端)