一、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