@mapper 和@service注解的区别
时间: 2024-06-15 13:04:17 浏览: 168
在Java开发中,@Mapper和@Service是两个常用的注解,它们的作用和使用场景有所不同。
@Mapper注解通常用于MyBatis框架中,用于标识一个接口是数据访问层的Mapper接口。Mapper接口定义了数据库操作的方法,通过@Mapper注解告诉MyBatis框架该接口是一个Mapper接口,需要由框架自动生成对应的实现类。@Mapper注解可以减少手动编写Mapper接口实现类的工作量,提高开发效率。
@Service注解是Spring框架中的注解,用于标识一个类是业务逻辑层的组件。通常情况下,我们将业务逻辑的实现放在Service类中,通过@Service注解告诉Spring框架该类是一个Service组件,需要由框架进行管理和依赖注入。Service组件负责处理业务逻辑,调用数据访问层的方法获取数据,并进行相应的处理和转换。
总结一下区别:
- @Mapper注解用于标识数据访问层的Mapper接口,主要与MyBatis框架相关;
- @Service注解用于标识业务逻辑层的组件,主要与Spring框架相关。
相关问题
运用spring boot框架用@Controller @ResponseBody@Autowired@PostMapping@Service@Mapper@Data注解和xml编写sql语句实现用户登录案例
好的,下面给出一个简单的用户登录案例,使用了Spring Boot框架、MyBatis、MySQL数据库。
首先,需要在pom.xml文件中添加相关依赖:
```xml
<dependencies>
<!-- Spring Boot -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!-- MyBatis -->
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>2.1.4</version>
</dependency>
<!-- MySQL -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.26</version>
</dependency>
</dependencies>
```
然后,在application.properties文件中配置数据库连接信息:
```properties
spring.datasource.url=jdbc:mysql://localhost:3306/db_name?useSSL=false&serverTimezone=UTC&useUnicode=true&characterEncoding=UTF-8
spring.datasource.username=username
spring.datasource.password=password
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
mybatis.mapper-locations=classpath:mapper/*.xml
```
接下来,创建一个User实体类:
```java
@Data
public class User {
private Integer id;
private String username;
private String password;
}
```
然后,在resources目录下创建mapper/UserMapper.xml文件,编写SQL语句:
```xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.example.demo.mapper.UserMapper">
<resultMap id="userMap" type="com.example.demo.entity.User">
<id column="id" property="id"/>
<result column="username" property="username"/>
<result column="password" property="password"/>
</resultMap>
<select id="findByUsernameAndPassword" resultMap="userMap">
select * from user where username=#{username} and password=#{password}
</select>
</mapper>
```
然后,在com.example.demo.mapper包下创建UserMapper接口:
```java
@Mapper
public interface UserMapper {
User findByUsernameAndPassword(@Param("username") String username, @Param("password") String password);
}
```
接着,在com.example.demo.service包下创建UserService接口和实现类UserServiceImpl:
```java
@Service
public class UserServiceImpl implements UserService {
@Autowired
private UserMapper userMapper;
@Override
public User findByUsernameAndPassword(String username, String password) {
return userMapper.findByUsernameAndPassword(username, password);
}
}
```
最后,在com.example.demo.controller包下创建UserController:
```java
@Controller
public class UserController {
@Autowired
private UserService userService;
@PostMapping("/login")
@ResponseBody
public String login(String username, String password) {
User user = userService.findByUsernameAndPassword(username, password);
if (user == null) {
return "登录失败";
} else {
return "登录成功";
}
}
}
```
这样,我们就完成了一个简单的用户登录案例。需要注意的是,这里只是一个简单的示例,实际应用中还需要进行参数校验、异常处理等。
运用spring boot框架用@RestController@RequestParam@Autowired@PostMapping@Service@Mapper@Data注解和xml<select>语句用resultType数据库mysql实现用户登录案例
以下是一个简单的spring boot框架下实现用户登录的示例代码:
User.java
```java
package com.example.demo.model;
import lombok.Data;
@Data
public class User {
private String username;
private String password;
}
```
UserMapper.java
```java
package com.example.demo.mapper;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select;
import com.example.demo.model.User;
@Mapper
public interface UserMapper {
@Select("SELECT * FROM user WHERE username=#{username} AND password=#{password}")
User login(@Param("username") String username, @Param("password") String password);
}
```
UserService.java
```java
package com.example.demo.service;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import com.example.demo.mapper.UserMapper;
import com.example.demo.model.User;
@Service
public class UserService {
@Autowired
private UserMapper userMapper;
public User login(String username, String password) {
return userMapper.login(username, password);
}
}
```
UserController.java
```java
package com.example.demo.controller;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import com.example.demo.model.User;
import com.example.demo.service.UserService;
@RestController
public class UserController {
@Autowired
private UserService userService;
@PostMapping("/login")
public String login(@RequestParam String username, @RequestParam String password) {
User user = userService.login(username, password);
if (user == null) {
return "登录失败";
} else {
return "登录成功";
}
}
}
```
application.properties
```properties
spring.datasource.url=jdbc:mysql://localhost:3306/test?useSSL=false&serverTimezone=UTC
spring.datasource.username=root
spring.datasource.password=root
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
```
以上代码中,使用了@RestController注解将UserController声明为一个控制器,@PostMapping注解将login方法映射到/login接口,@RequestParam注解用于接收请求参数,@Autowired注解用于依赖注入,@Service注解用于声明UserService为一个服务,@Mapper注解用于声明UserMapper为一个Mapper,@Data注解用于自动生成getter、setter和toString方法。在UserMapper中使用了<select>语句和resultType属性实现了查询,同时使用了@Param注解指定参数名。application.properties中配置了数据库连接信息。这样,当用户访问/login接口时,会调用UserController的login方法,该方法调用了UserService的login方法,后者又调用了UserMapper的login方法,最终返回用户登录信息。
阅读全文