举个栗子:

传统访问数据库的方法非常面向过程,分为以下几步
– 实例化connection
– 实例化statement
– 通过statement的参数sql语句访问数据库,返回数据进行处理

import java.sql.Statement;
import java.util.Properties;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;public class DBAccess {public static void main(String[] args) throws SQLException, FileNotFoundException, IOException{DBAccess access = new DBAccess();access.test();}private void test() throws SQLException, FileNotFoundException, IOException{String url = "jdbc:postgresql://localhost:5432/rylynn"; Properties p = new Properties();p.load(new FileInputStream("reg.txt"));Connection connection = DriverManager.getConnection(url,p);       //建立connectionStatement statement = connection.createStatement();       //建立satatementstatement.execute("insert into abo values((001),'hnb')");       //执行sql语句ResultSet resultSet = statement.executeQuery("select number from abo where number < 2");while(resultSet.next()){int id = resultSet.getInt(1);//      String name = resultSet.getString(1);System.out.println("ID:" + id);}statement.close();connection.close();}
}

传统数据库访问模式缺点显而易见:
一就是各个模块间的耦合太紧,statement要依赖connection,connection还依赖于数据库的种类。
二就是如果我改变的数据库的种类,或者要提供不同的数据库服务,那么我就要提供大量的重复代码。

dao层:

dao层叫数据访问层,全称为data access object,属于一种比较底层,比较基础的操作,具体到对于某个表、某个实体的增删改查。

service层:

service层叫服务层,被称为服务,肯定是相比之下比较高层次的一层结构,相当于将几种操作封装起来,至于为什么service层要使用接口来定义有以下几点好处:
service实现类:也顾名思义,service实现类实现了service接口,进行具体的业务操作。
在java中接口是多继承的,而类是单继承的,如果你需要一个类实现多个service,你用接口可以实现,用类定义service就没那么灵活
要提供不同的数据库的服务时,我们只需要面对接口用不同的类实现即可,而不用重复地定义类
编程规范问题,接口化的编程为的就是将实现封装起来,然调用者只关心接口不关心实现,也就是“高内聚,低耦合”的思想。

以对于user的操作为例进行说明:
userdao:

public interface UserDao {public List<User> findAll();public User findById(String id);public void update(User user);public void add(User user);public void delete(String id);public User findByIdAndPassword(@Param("id") String username, @Param("password") String password);public void updatePassword(@Param("userId") String id, @Param("password") String password);User findByUsername(String username);
}

在接口中对方法进行了定义,在UserDao.xml中给出了sql语句实现
在UserDao中,就对user这个实体的增删补查各类基本的操作进行了声明,并用mybatis框架进行实现。

下面给出部分UserDao.xml的代码

<select id="findAll" resultMap="user_map">SELECT * FROM user WHERE user_id != 'admin'</select><select id="findById" parameterType="String" resultMap="user_map">SELECT * FROM user WHERE user_id = #{value}</select><update id="update" parameterType="User">UPDATE user SET password = #{password} ,authority = #{authority} WHERE user_id = #{userId}</update><update id="updatePassword" parameterType="map">UPDATE user SET password = #{password} WHERE user_id = #{userId}</update><insert id="add" parameterType="User">INSERT INTO user(user_id,password,salt,role_ids,locked) VALUES(#{userId},#{password},#{salt},#{roleIdsStr},#{locked})</insert><select id="findByIdAndPassword" parameterType="map" resultMap="user_map">SELECT * FROM user WHERE user_id = #{id} AND password = #{password}</select>

下面来看看service层的代码

import com.giit.www.entity.User;
import com.giit.www.entity.custom.UserVo;import java.lang.reflect.InvocationTargetException;
import java.util.List;
import java.util.Set;/*** Created by c0de8ug on 16-2-9.*/
public interface UserBiz {public List<UserVo> findAll() throws InvocationTargetException, IllegalAccessException;public User findById(String id);public void update(User user);public void add(User user);public void delete(String id);public void changePassword(String userId, String newPassword);public User findByUsername(String username);public Set<String> findRoles(String username);public Set<String> findPermissions(String username);
}

显然,service层里面的方法相较于dao层中的方法进行了一层包装,例如通过id查找用户,通过用户名查找用户,是在基础的操作上又增加了一层包装的,实现的是相对高级的操作。最后将这些操作在serviceimpl类中实现,代码比较多,这里还是只给出了部分代码。

import com.giit.www.college.dao.StaffDao;
import com.giit.www.entity.Role;
import com.giit.www.entity.Staff;
import com.giit.www.entity.User;
import com.giit.www.entity.custom.UserVo;
import com.giit.www.system.dao.RoleDao;
import com.giit.www.system.dao.UserDao;
import com.giit.www.system.service.RoleBiz;
import com.giit.www.system.service.UserBiz;
import com.giit.www.util.PasswordHelper;
import org.apache.commons.beanutils.BeanUtils;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;import javax.annotation.Resource;
import java.lang.reflect.InvocationTargetException;
import java.util.*;/*** Created by c0de8ug on 16-2-9.*/@Service
public class UserBizImpl implements UserBiz {@ResourceUserDao userDao;@ResourceRoleDao roleDao;@ResourceStaffDao staffDao;@Resourceprivate PasswordHelper passwordHelper;@Resource(name = "roleBizImpl")private RoleBiz roleBiz;@Overridepublic List<UserVo> findAll() throws InvocationTargetException, IllegalAccessException {List<UserVo> userVoList = new ArrayList<>();List userList = userDao.findAll();Iterator iterator = userList.iterator();while (iterator.hasNext()) {StringBuilder s = new StringBuilder();User user = (User) iterator.next();List<Long> roleIds = user.getRoleIds();UserVo userVo = new UserVo();BeanUtils.copyProperties(userVo, user);if (roleIds != null) {int i = 0;int size = roleIds.size();for (; i < size - 1; i++) {Role role = roleDao.findOne(roleIds.get(i));s.append(role.getDescription());s.append(",");}Role role = roleDao.findOne(roleIds.get(i));s.append(role.getDescription());userVo.setRoleIdsStr(s.toString());}userVoList.add(userVo);}return userVoList;}

由此看到,这样进行分层,访问数据库和进行service之间的分工明确,如果我需要对service的需求修改,无需改变dao层的代码,只要在实现上改变即可,如果我有访问数据库的新需求,那我也只要在dao层的代码中增添即可。

摘自:https://www.cnblogs.com/sageliu/articles/7768920.html

Dao层和Service层的区别相关推荐

  1. java dao层 service层_Java中DAO层、Service层和Controller层的区别

    DAO层: DAO层叫数据访问层,全称为data access object,属于一种比较底层,比较基础的操作,具体到对于某个表的增删改查,也就是说某个DAO一定是和数据库的某一张表一一对应的,其中封 ...

  2. java中DAO层、Service层、Controller层的区别

    DAO层: DAO层叫数据访问层,全称为data access object,属于一种比较底层,比较基础的操作,具体到对于某个表的增删改查,也就是说某个DAO一定是和数据库的某一张表一一对应的,其中封 ...

  3. java的dao层_Java中DAO层、Service层和Controller层的区别

    DAO层: DAO层叫数据访问层,全称为data access object,属于一种比较底层,比较基础的操作,具体到对于某个表的增删改查,也就是说某个DAO一定是和数据库的某一张表一一对应的,其中封 ...

  4. Java中DAO层、Service层和Controller层的区别

    DAO层: DAO层叫数据访问层,全称为data access object,属于一种比较底层,比较基础的操作,具体到对于某个表的增删改查,也就是说某个DAO一定是和数据库的某一张表一一对应的,其中封 ...

  5. Java中dao层、service层、controller层、entity层和view层的概述

    目录 DAO层:(持久层)主要与数据库进行交互 Service层:(业务层 )控制业务 Controler层:(控制层 )控制业务逻辑 Entity层: (实体层 )数据库在项目中的类 View层: ...

  6. DAO层、ENTITY层、SERVICE层、CONTROLLER层

    dao层.entity层.service层.controller层 2018年08月09日 11:02:31 一江春华终散去 阅读数:3074 版权声明:本文为博主原创文章,未经博主允许不得转载. h ...

  7. SpringBoot框架中的DAO(mapper)层、Entity层、Service层、Controller层

    Entity层:实体层 数据库在项目中的类 Entity层是实体层,也就是所谓的model,也称为pojo层,是数据库在项目中的类,该文件包含实体类的属性和对应属性的set.get方法: DAO层: ...

  8. OA系统二十四:请假审批五:【点击“审批”后的审批弹出框】的后台逻辑;(审批结果提交的Dao层和Service层逻辑)

    本篇博客的主要内容是:[请假审批内嵌页面],[审批弹出框]的点击"确认提交"后,后台的逻辑:主要是Dao层和Service层这些后台逻辑:  说明: (1)目前来看,为了实现某个功 ...

  9. pojo层、dao层、service层、controller层的作用

    pojo层(model) 实体层 数据库在项目中的类 model是模型的意思,与entity.domain.pojo类似,是存放实体的类. 类中定义了多个类属性,并与数据库表的字段保持一致,一张表对应 ...

最新文章

  1. 北电ERS1600,8300,8600交换机的基本技术-第六章 二层冗余技术(MLT,SMLT,IST)
  2. Shell脚本_备份/etc数据
  3. 跟前腾讯总监学Java实战项目
  4. 组合数据类型综合练习
  5. nil,Nil,NULL,NSNull
  6. Android官方开发文档Training系列课程中文版:键盘输入处理之处理键盘按键
  7. 洛谷 1972 莫队
  8. python的循环控制结构是什么_7.Python控制和循环结构
  9. webpack, react项目中利用外部JS库提升效率
  10. “微积分7天搞定”学习记录
  11. Github Actions 云编译 OpenWRT LEDE 固件
  12. c花体复制_可复制花体字大全?
  13. 眼镜寿命不仅跟镜架材质有关,还跟习惯有关系!
  14. 基于Python的招聘信息可视化分析研究
  15. 大连海事大学计算机基础线上考试虚拟机环境配置
  16. HTML 文字行间距与文字间距属性
  17. 关于面试的一些总结,仅供参考,希望大家指正投入学习
  18. 海信网络科技软件研发实习面试
  19. 关于时间:UTC/GMT/xST/ xDT
  20. 总结程序员的性格特点、生活习惯

热门文章

  1. RGB颜色空间、色调、饱和度、亮度、HSV颜色空间详解
  2. 同样是手写笔,Apple Pencil到底输在了哪里?
  3. 生产线平衡优化毕业论文【flexsim仿真】
  4. GEE-Scholars MODIS地表温度LST时间变化趋势
  5. 入门须知:次世代3D建模软件有哪些?
  6. Replacing TCP Wrappers in RHEL 8
  7. PS_变量批量生产名片
  8. 2022/5/1 Mybatis框架动态SQL
  9. 使用Telerik的登陆模板实现DoubanFm的登陆(WP7)
  10. 毕业一周年--IT在路上