Mapper層和Dao層詳解

一、Mapper層和Dao層的區別

Mapper和Dao都是用來訪問資料庫的,但是它們的職責不一樣。Mapper主要負責將SQL語句映射成對應的Java方法,並提供必要的參數和返回值;而Dao層則是對業務邏輯的抽象,封裝對資料庫的增刪改查操作,以供Service層調用。

在Mybatis框架中,Mapper層是Dao層的一種實現方式,是Mybatis提供的。因此,我們在實際項目中可看到使用Mapper層的案例,也可見到使用Dao層的案例,這兩種方式可根據個人喜好和實際情況來選擇。

二、Mapper層怎麼寫

Mapper層主要是通過Mybatis的SqlSessionFactory來獲取SqlSession,用SqlSession來操作資料庫。在Mapper層中,我們需要定義對應的Mapper介面,並編寫對應的XML文件,用於綁定介面和SQL語句。

下面是一個使用Mapper層的示例:


// 定義Mapper介面
public interface UserMapper {
    List<User> getUserList();

    void addUser(User user);

    void deleteUserById(int id);
}

// 編寫Mapper XML文件
<mapper namespace="com.example.mapper.UserMapper">
    <select id="getUserList" resultType="User">
        select * from user;
    </select>

    <insert id="addUser" parameterType="User">
        insert into user(name, age) values(#{name}, #{age})
    </insert>

    <delete id="deleteUserById" parameterType="int">
        delete from user where id = #{id}
    </delete>
</mapper>

// 在Service層中調用Mapper層
@Autowired
private UserMapper userMapper;

public List<User> getUserList() {
    return userMapper.getUserList();
}

public void addUser(User user) {
    userMapper.addUser(user);
}

public void deleteUserById(int id) {
    userMapper.deleteUserById(id);
}

三、Dao層和Mapper層的關係

Dao層是一個業務邏輯的抽象,它不同於Mapper、不同於Service、也不同於Controller。Dao層的主要職責是封裝對資料庫的操作,以供Service層調用。在Dao層中,可以使用Mybatis提供的Mapper層來進行對資料庫的訪問。

下面是一個使用Dao層的示例:


@Repository
public class UserDao {
    @Autowired
    private UserMapper userMapper;

    public List<User> getUserList() {
        return userMapper.getUserList();
    }

    public void addUser(User user) {
        userMapper.addUser(user);
    }

    public void deleteUserById(int id) {
        userMapper.deleteUserById(id);
    }
}

@Service
public class UserService {
    @Autowired
    private UserDao userDao;

    public List<User> getUserList() {
        return userDao.getUserList();
    }

    public void addUser(User user) {
        userDao.addUser(user);
    }

    public void deleteUserById(int id) {
        userDao.deleteUserById(id);
    }
}

@Controller
public class UserController {
    @Autowired
    private UserService userService;

    @GetMapping("/getUserList")
    public String getUserList(Model model) {
        List<User> userList = userService.getUserList();
        model.addAttribute("userList", userList);
        return "userList";
    }

    @PostMapping("/addUser")
    public String addUser(User user) {
        userService.addUser(user);
        return "redirect:/getUserList";
    }

    @DeleteMapping("/deleteUserById/{id}")
    public String deleteUserById(@PathVariable("id") int id) {
        userService.deleteUserById(id);
        return "redirect:/getUserList";
    }
}

四、Mapper層和Service層的關係

Service層是業務邏輯的實現,它負責處理業務邏輯,並調用Dao層來對資料庫進行增刪改查操作。Mapper層的作用是將SQL語句映射成對應的Java方法,並提供必要的參數和返回值,Service層可以直接使用Mapper層提供的方法,簡化了Service層的代碼。

下面是一個使用Mapper層和Service層的示例:


// 定義Mapper介面
public interface UserMapper {
    List<User> getUserList();

    void addUser(User user);

    void deleteUserById(int id);
}

// 在Service層中調用Mapper層
@Autowired
private UserMapper userMapper;

public List<User> getUserList() {
    return userMapper.getUserList();
}

public void addUser(User user) {
    userMapper.addUser(user);
}

public void deleteUserById(int id) {
    userMapper.deleteUserById(id);
}

五、Mapper層是幹什麼的

Mapper層是用來將SQL語句映射成對應的Java方法,Mapper層一般使用XML文件或註解來綁定SQL語句和Java方法。Mapper層提供了必要的參數和返回值,並使用SqlSession來對資料庫進行操作,最終將結果返回給調用者。

六、是否應該用Dao層還是Mapper層

在Mybatis框架中,Mapper層是Dao層的一種實現方式。因此,我們在實際項目中可看到使用Mapper層的案例,也可見到使用Dao層的案例,這兩種方式可根據個人喜好和實際情況來選擇。

如果一個項目需要對資料庫進行複雜的操作,建議使用Dao層;如果操作較簡單,可以考慮使用Mapper層,因為使用Mapper層可以簡化代碼。

七、Mapper和Dao層的關係

Dao層是一個業務邏輯的抽象,它不同於Mapper、不同於Service、也不同於Controller。Dao層的主要職責是封裝對資料庫的操作,以供Service層調用。在Dao層中,可以使用Mybatis提供的Mapper層來進行對資料庫的訪問。

Mapper層相當於Dao層的一個實現方式,它是Mybatis提供的一種直接訪問資料庫的方式。Mapper層將SQL語句映射成對應的Java方法,並提供必要的參數和返回值,使用SqlSession來對資料庫進行操作。在實際項目中,可以根據個人喜好和實際情況來選擇使用Mapper層還是Dao層。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/150844.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-11-09 02:14
下一篇 2024-11-09 02:14

相關推薦

  • Spring Boot中使用DTO、Controller、Service、Mapper進行開發

    本文將介紹如何在Spring Boot中使用DTO、Controller、Service、Mapper等技術進行開發。 一、DTO DTO(Data Transfer Object…

    編程 2025-04-28
  • Linux sync詳解

    一、sync概述 sync是Linux中一個非常重要的命令,它可以將文件系統緩存中的內容,強制寫入磁碟中。在執行sync之前,所有的文件系統更新將不會立即寫入磁碟,而是先緩存在內存…

    編程 2025-04-25
  • 神經網路代碼詳解

    神經網路作為一種人工智慧技術,被廣泛應用於語音識別、圖像識別、自然語言處理等領域。而神經網路的模型編寫,離不開代碼。本文將從多個方面詳細闡述神經網路模型編寫的代碼技術。 一、神經網…

    編程 2025-04-25
  • nginx與apache應用開發詳解

    一、概述 nginx和apache都是常見的web伺服器。nginx是一個高性能的反向代理web伺服器,將負載均衡和緩存集成在了一起,可以動靜分離。apache是一個可擴展的web…

    編程 2025-04-25
  • git config user.name的詳解

    一、為什麼要使用git config user.name? git是一個非常流行的分散式版本控制系統,很多程序員都會用到它。在使用git commit提交代碼時,需要記錄commi…

    編程 2025-04-25
  • Java BigDecimal 精度詳解

    一、基礎概念 Java BigDecimal 是一個用於高精度計算的類。普通的 double 或 float 類型只能精確表示有限的數字,而對於需要高精度計算的場景,BigDeci…

    編程 2025-04-25
  • 詳解eclipse設置

    一、安裝與基礎設置 1、下載eclipse並進行安裝。 2、打開eclipse,選擇對應的工作空間路徑。 File -> Switch Workspace -> [選擇…

    編程 2025-04-25
  • Python輸入輸出詳解

    一、文件讀寫 Python中文件的讀寫操作是必不可少的基本技能之一。讀寫文件分別使用open()函數中的’r’和’w’參數,讀取文件…

    編程 2025-04-25
  • Linux修改文件名命令詳解

    在Linux系統中,修改文件名是一個很常見的操作。Linux提供了多種方式來修改文件名,這篇文章將介紹Linux修改文件名的詳細操作。 一、mv命令 mv命令是Linux下的常用命…

    編程 2025-04-25
  • MPU6050工作原理詳解

    一、什麼是MPU6050 MPU6050是一種六軸慣性感測器,能夠同時測量加速度和角速度。它由三個感測器組成:一個三軸加速度計和一個三軸陀螺儀。這個組合提供了非常精細的姿態解算,其…

    編程 2025-04-25

發表回復

登錄後才能評論