spring boot是一种快速开发框架,可以帮助开发人员快速搭建web应用程序。而mybatis是一种优秀的orm框架,可以简化java与数据库之间的数据访问和持久化。本文将介绍如何在spring boot中使用mybatis实现数据访问和持久化。
一、Spring Boot集成MyBatis
添加依赖
在pom.xml文件中添加MyBatis和MySQL依赖:
org.mybatis.spring.bootmybatis-spring-boot-starter1.3.1mysqlmysql-connector-java5.1.42
登录后复制
这里我们使用mybatis-spring-boot-starter来集成MyBatis。
配置数据源
在application.properties中添加数据库连接属性:
spring.datasource.url=jdbc:mysql://localhost:3306/test?useSSL=falsespring.datasource.username=rootspring.datasource.password=123456spring.datasource.driverClassName=com.mysql.jdbc.Driver
登录后复制
这里我们使用MySQL数据库,并且使用root账户连接,密码为123456。
配置MyBatis
Spring Boot默认会自动扫描mapper路径,我们只需要在application.properties中配置mapper路径即可:
mybatis.mapper-locations=classpath:mapper/*.xml
登录后复制
该配置表示mapper文件在项目的classpath下的mapper文件夹中。
在完成以上配置后,Spring Boot就已经完成了对MyBatis的集成工作。
二、编写实体类和Mapper
编写实体类
定义一个User类,表示数据库中的一张用户表:
public class User { private Long id; private String name; private Integer age; // 省略getter和setter方法}
登录后复制编写Mapper
定义一个UserMapper接口,用于定义User表的增删改查操作:
public interface UserMapper { void saveUser(User user); void updateUser(User user); void deleteUser(Long id); User findUserById(Long id); List findAllUsers();}
登录后复制
这里我们定义了增删改查以及查询所有用户的方法。
三、编写Mapper.xml
接下来,我们需要编写UserMapper.xml文件,实现UserMapper中定义的操作:
insert into user(name, age) values (#{name}, #{age}) update user set name = #{name}, age = #{age} where id = #{id} delete from user where id = #{id} select * from user where id = #{id} select * from user
登录后复制
在该文件中,我们实现了UserMapper中定义的所有方法,其中parameterType表示参数类型,resultType表示返回值类型。
四、编写Service类和控制器
编写Service类
定义一个UserService类,用于封装对User表的操作:
@Servicepublic class UserService { @Autowired private UserMapper userMapper; public void saveUser(User user) { userMapper.saveUser(user); } public void updateUser(User user) { userMapper.updateUser(user); } public void deleteUser(Long id) { userMapper.deleteUser(id); } public User findUserById(Long id) { return userMapper.findUserById(id); } public List findAllUsers() { return userMapper.findAllUsers(); }}
登录后复制
在这个类中,我们使用@Autowired注解注入了UserMapper,即可以使用UserMapper中定义的方法。
编写控制器
定义一个UserController类,实现对用户的增删改查操作:
@RestController@RequestMapping("/user")public class UserController { @Autowired private UserService userService; @PostMapping("/") public String saveUser(@RequestBody User user) { userService.saveUser(user); return "success"; } @PutMapping("/") public String updateUser(@RequestBody User user) { userService.updateUser(user); return "success"; } @DeleteMapping("/{id}") public String deleteUser(@PathVariable Long id) { userService.deleteUser(id); return "success"; } @GetMapping("/{id}") public User getUserById(@PathVariable Long id) { return userService.findUserById(id); } @GetMapping("/") public List findAllUsers() { return userService.findAllUsers(); }}
登录后复制
在这个类中,我们使用@RestController注解表示当前类是一个控制器,使用@RequestMapping注解指定了访问路径。同时,使用@Autowired注解注入了UserService,即可以使用UserService中定义的方法。
五、测试
现在,我们已经完成了整个项目的搭建和代码编写。接下来,我们可以使用Postman等工具来测试控制器中定义的API。
使用POST请求来保存用户信息,请求体为:
{ "name": "张三", "age": 18}
登录后复制
使用PUT请求来更新用户信息,请求体为:
{ "id": 1, "name": "李四", "age": 20}
登录后复制
使用DELETE请求来删除用户信息,URL为:
http://localhost:8080/user/1
登录后复制登录后复制
使用GET请求来获取用户信息,URL为:
http://localhost:8080/user/1
登录后复制登录后复制
使用GET请求来获取所有用户信息,URL为:
http://localhost:8080/user/
登录后复制
六、总结
本文介绍了如何在Spring Boot中使用MyBatis实现数据访问和持久化,并使用了一个简单的示例来说明整个流程。MyBatis可以使得Java程序对数据库的操作变得更加高效和简洁,如果您需要在Spring Boot中实现对数据库的操作,可以考虑使用MyBatis。
以上就是Spring Boot中使用MyBatis实现数据访问和持久化的详细内容,更多请关注【创想鸟】其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。
发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2625152.html