前面两篇文章我们讲了两件事情:
这篇文章我们来看下怎么通过JdbcTemplate进行数据的持久化。
废话不多说,直接上干货。
一、代码实现
- 修改pom文件,引入相关依赖
<!-- 引入jdbc 依赖 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-jdbc</artifactId> </dependency> <!-- 引入 mysql 数据库连接依赖--> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> </dependency>
- 配置数据库信息,在application.properties中添加如下内容:
spring.datasource.driver-class-name=com.mysql.jdbc.Driver spring.datasource.url=jdbc:mysql://localhost:3306/test spring.datasource.username=root spring.datasource.password=root
- 创建实体类并创建数据库
- 实体类
package com.study.entity; public class User { private Integer id; private String userName; private String password; public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } public String getUserName() { return userName; } public void setUserName(String userName) { this.userName = userName; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } }
- 数据库
- 实体类
- 实现dao层
@Repository public class UserDao { @Autowired JdbcTemplate jdbcTemplate; public void save(User user) { String sql = "insert into t_user(user_name, password) values(?,?)"; jdbcTemplate.update(sql, user.getUserName(), user.getPassword()); } }
- 实现service层
- 接口
public interface UserService { public void save(User user); }
- 实现类
@Service public class UserServiceImpl implements UserService { @Autowired UserDao userDao; public void save(User user){ userDao.save(user); } }
- 接口
- 实现controller层
@RestController public class UserController { @Autowired UserService service; @RequestMapping("/saveUser") public String saveUser(User user) { service.save(user); return "save user successful"; } }
- 测试
- 页面正确返回信息
- 数据库正确保存
二、总结
由此我们发现,spring boot 只是简化了xml的配置麻烦,并没有减少我们java代码的编写量。
spring boot 不是spring 功能的增强,而是提供了一种快速使用spring 的方式:开箱即用,没有代码生成,也无需XML配置。