jdbcTemplate的简单使用

开始前的准备工作

本次介绍jdbcTemplate是在springboot2.x版本总使用的,因为springboot自动已经把jdbcTemplate自动注册到容器中,我们可以直接使用。

创建springboot项目,然后再pom.xml中导入数据库连接依赖:

 <dependency>
    <groupId>mysql</groupId>
     <artifactId>mysql-connector-java</artifactId>
     <version>8.0.27</version>
 </dependency>

然后配置数据库连接信息,在application.yaml配置文件中:(注意换成自己的数据库和用户,密码)

spring:
  datasource:
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://localhost:3306/springboot-test-db?serverTimezone=Asia/Shanghai&characterEncoding=utf8&useSSL=false
    username: root
    password: root

接下来就是创建数据库和创建用户Bean。(自己创建不介绍了)

JdbcTemplate简介

JdbcTemplate是Spring对JDBC的封装,目的是使JDBC更加易于使用。Spring对数据库的操作在jdbc上面做了深层次的封装,使用spring的注入功能,可以把DataSource注册到JdbcTemplate.之中。

JDBCTemplate的增删改查

update() – 执行DML语句(可以执行增删改操作)
queryForMap() – 查询结果,将结果封装为map集合
queryForList() – 查询结果,将结果封装为List集合
queryForObject() – 查询结果,将结果封装为对象,一般用于查询聚合函数
query() – 查询结果,将结果封装为JavaBean对象。第二个参数为RowMapper,一般使用BeanPropertyRowMapper实现类,可以完成数据到JavaBean的自动封装,演示在下方text6和text7中


	@Autowired
    JdbcTemplate jdbcTemplate;
    
	// JDBCTemplate添加数据
	public static void test01() throws Exception {
		 String sql = "INSERT INTO tbl_user(name,age,email) VALUES (?, ?, ?);";
        int update = jdbcTemplate.update(sql, "张三", "23", "zhangsan@qq.com");
	}
	
	// JDBCTemplate修改数据
	public static void test02() throws Exception {
		String sql = "UPDATE tbl_user SET name=?, age=? WHERE email=?;";
		int i = jdbcTemplate.update(sql, "张三", "23", "zhangsan@qq.com");
		System.out.println("影响的行数: " + i);
	}

	// JDBCTemplate删除数据
	public static void test03() throws Exception {
		String sql = "DELETE FROM tbl_user WHERE id=?;";
		int i = jdbcTemplate.update(sql, 7);
		System.out.println("影响的行数: " + i);
	}

查询单个(如查询指定性别的用户数量)

public T queryForObject(String sql, Object[] args, Class requiredType)

参数分别是sql,sql参数数组,返回数据类型(这里我们就返回Integer)


     /**
     * 查询单个用户信息
     * @return
     */
    @GetMapping("/user/{id}")
    public User userById(@PathVariable("id") Long id){
        String sql = "select * from tbl_user where id = ?";
        User query = jdbcTemplate.queryForObject(sql,new Object[]{id},new BeanPropertyRowMapper<>(User.class));
        return query;
    }

查询列表(查询所有用户列表,含分页)

public List query(String sql, @Nullable Object[] args, RowMapper rowMapper)

参数分别是sql,sql参数数组(可为空),对象映射关系

 /**
     * 查询全部用户信息
     * @return
     */
    @GetMapping("/userlist")
    public List<User> userList(){
        String sql = "select * from tbl_user ";
        List<User> userList = jdbcTemplate.query(sql, new BeanPropertyRowMapper<>(User.class));
        return userList;
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用Spring Boot的JdbcTemplate之前,需要在项目的依赖中添加Spring Boot JDBC模块的引用。在pom.xml文件中添加以下依赖: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-jdbc</artifactId> </dependency> ``` 接下来,你可以创建一个数据访问层的类,使用JdbcTemplate来执行SQL操作。以下是一个简单的示例: ```java import org.springframework.beans.factory.annotation.Autowired; import org.springframework.jdbc.core.JdbcTemplate; import org.springframework.stereotype.Repository; @Repository public class MyRepository { private final JdbcTemplate jdbcTemplate; @Autowired public MyRepository(JdbcTemplate jdbcTemplate) { this.jdbcTemplate = jdbcTemplate; } public void insertData(String data) { String sql = "INSERT INTO my_table (column_name) VALUES (?)"; jdbcTemplate.update(sql, data); } // 其他数据操作方法... } ``` 在上述示例中,我们通过@Autowired注解将JdbcTemplate注入到MyRepository类中。然后,可以使用jdbcTemplate对象执行SQL操作,比如插入数据。 请注意,上述示例假设已经在配置文件中正确配置了数据源信息,包括数据库的URL、用户名和密码等。如果没有配置,可以在application.properties文件中添加相关配置。 这只是一个简单的示例,JdbcTemplate还提供了许多其他强大的功能,如查询数据、更新数据、批量操作等。你可以根据具体的需求来使用JdbcTemplate提供的方法。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值