玩转springboot:整合JdbcTemplate访问数据库进行操作

本人花费半年的时间总结的《Java面试指南》已拿腾讯等大厂offer,已开源在github ,欢迎star!

本文GitHub https://github.com/OUYANGSIHAI/JavaInterview 已收录,这是我花了6个月总结的一线大厂Java面试总结,本人已拿大厂offer,欢迎star

原文链接:blog.ouyangsihai.cn >> 玩转springboot:整合JdbcTemplate访问数据库进行操作

这篇文章我们看一下springboot整合jdbc,做一个小例子来讲解。

数据源配置

pom.xml文件中导入


<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring‐boot‐starter‐jdbc</artifactId>
</dependency>
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql‐connector‐java</artifactId>
    <scope>runtime</scope>
</dependency>

然后在 application.properties中配置数据库信息:


spring.datasource.url=jdbc:mysql://localhost:3306/test
spring.datasource.username=root
spring.datasource.password=0911SIHAI
spring.datasource.driver-class-name=com.mysql.jdbc.Driver

使用JdbcTemplate操作数据库

这里我们以 user进行对数据库的操作,做一个小例子

user代码:


/**
 * @author 欧阳思海
 * @date 2018/7/26 16:09
 */
public class User {


    private String username;

    private String password;

    //getter setter
}
  • 定义包含有插入、删除、查询的抽象接口UserService

/**
 * @author 欧阳思海
 * @date 2018/7/26 16:07
 */
public interface UserService {

    /**
     * 新增用户
     * @param username
     * @param password
     */
    void add(String username, String password);

    /**
     * 根据name删除一个用户高
     * @param userName
     */
    void deleteByName(String userName);

    /**
     * 获取所有用户
     */
    List<User> getAllUsers();


}
  • 通过JdbcTemplate实现UserService中定义的数据访问操作

/**
 * @author 欧阳思海
 * @date 2018/7/26 16:11
 */
@Service
public class UserServiceImpl implements UserService {

    @Autowired
    private JdbcTemplate jdbcTemplate;

    @Override
    public void add(String username, String password) {
        jdbcTemplate.update("insert into user values (?,?)",username,password);
    }

    @Override
    public void deleteByName(String userName) {
        jdbcTemplate.update("delete from user where username = ?",userName);
    }

    @Override
    public List<User> getAllUsers() {
        return jdbcTemplate.query("select * from user",
                new RowMapper(){
                    @Override
                    public Object mapRow(ResultSet rs, int rowNum) throws SQLException {
                        User user  = new User();
                        user.setUsername(rs.getString("username"));
                        user.setPassword(rs.getString("password"));
                        return user;
                    }
        } );
    }
}
  • 对用户操作进行测试

/**
 * @author 欧阳思海
 * @date 2018/7/26 16:22
 */
@RunWith(SpringRunner.class)
@SpringBootTest
public class UserTest {

    @Autowired
    private UserService userService;

    @Test
    public void testAdd(){

        userService.add("sihai","abc");
        userService.add("yan","abc");
    }

    @Test
    public void testQuery(){

        List<User> users = userService.getAllUsers();

        Assert.assertEquals(2, users.size());
    }
}

这里只是一个简单的例子,但是基本的jdbc的操作是有了,具体的jdbcTemplate的使用可以查看官方文档

下面有使用的具体实例

本人花费半年的时间总结的《Java面试指南》已拿腾讯等大厂offer,已开源在github ,欢迎star!

本文GitHub https://github.com/OUYANGSIHAI/JavaInterview 已收录,这是我花了6个月总结的一线大厂Java面试总结,本人已拿大厂offer,欢迎star

原文链接:blog.ouyangsihai.cn >> 玩转springboot:整合JdbcTemplate访问数据库进行操作


 上一篇
玩转springboot:实现springboot自定义拦截器 玩转springboot:实现springboot自定义拦截器
一、前言在javaee中,我们经常使用filter来做拦截器,后来有了springmvc,我们使用 HandlerInterceptor进行拦截,springmvc的拦截器查看这篇文章,现在有了springboot,我们使用HandlerI
下一篇 
玩转springboot:整合mybatis实例 玩转springboot:整合mybatis实例
这篇文章讲解一下springboot整合mybatis,其实,springboot整合mybatis和springmvc整合mybatis并没有什么太大的区别,大体上还是差不多哦,只是比springmvc更加的简单一点,下面我们就以一个例子