Spring5学习笔记(12) — “JdbcTemplate 操作数据库(查询 select)”

JdbcTemplate的查询操作分为三种情况:

1、查询返回某个值(例如:查询表中共有多少条数据)
JdbcTemplate 的 queryForObject 方法两个参数)实现
在这里插入图片描述
参数一:SQL语句
参数二:需要返回的类型(例如返回int类型,则参数填Integer.class)


2、查询返回一个表的实体类“对象”(例如:查询返回一行数据)
JdbcTemplate 的 queryForObject 方法三个参数)实现
在这里插入图片描述
参数一:SQL语句
参数二:RowMapper,是接口,返回不同类型数据,使用这个接口里面实现类完成数据封装
(该接口实现类为 BeanPropertyRowMapper< T >(T.class)
第三个参数:sql语句中传入的值


3、查询返回一个数据集合(例如:查询返回全表)
JdbcTemplate 的 query 方法两个参数)实现
在这里插入图片描述
参数一:SQL语句
参数二:RowMapper,是接口,返回不同类型数据,使用这个接口里面实现类完成数据封装
(该接口实现类为 BeanPropertyRowMapper< T >(T.class)


一、查询返回某个值

//1.编写bookDao接口
public interface bookDao {
    //1.查询返回某个值(查询表中共有多少条数据)
    int selectCount();
}

//2.编写接口实现类bookDaoImple
@Repository
    public class bookDaoImple implements bookDao{
      //注入JdbcTemplate
      @Autowired
      private JdbcTemplate jdbcTemplate;
        
	  //查询返回某个值
      @Override
      public int selectCount() {
          String sql = "select count(*) from book";
          int count = jdbcTemplate.queryForObject(sql, Integer.class);
          return count;
      }
}

//3.编写service类
@Service
public class bookService {

    //1.注入dao
    @Autowired
    private bookDao bookdao;

    //2.查询返回一行数据
    public book findBookinfo(String bookid){
        return bookdao.selectBookinfo(bookid);
    }

}

//4.编写测试类
     int count = bookservice.findCount();
     System.out.println("表中共有:"+count+"条语句");

二、查询返回一个表的实体类“对象”

//1.编写bookDao接口
public interface bookDao {
    //2.查询返回一个表的实体类对象(查询一行数据)
    book selectBookinfo(String bookid);
}

//2.编写接口实现类bookDaoImple
@Repository
    public class bookDaoImple implements bookDao{
      //注入JdbcTemplate
      @Autowired
      private JdbcTemplate jdbcTemplate;
       
      //查询返回一个表的实体类“对象”(一行数据) 
	  @Override
	  public book selectBookinfo(String bookid) {
	      String sql = "select * from book where bookid=?";
	      book bookreturn = jdbcTemplate.queryForObject(sql, new BeanPropertyRowMapper<book>(book.class),bookid);
	      return bookreturn;
	    }
}

//3.编写service类
@Service
public class bookService {

    //1.注入dao
    @Autowired
    private bookDao bookdao;

   //6.查询返回一行数据
    public book findBookinfo(String bookid){
        return bookdao.selectBookinfo(bookid);
    }

}

//4.编写测试类
        book bookinfo = bookservice.findBookinfo("1");
        System.out.println(bookinfo);

三、查询返回一个数据集合

//1.编写bookDao接口
public interface bookDao {
    //3.查询返回一个集合(返回一个表)
    List<book> selectAll();
}

//2.编写接口实现类bookDaoImple
@Repository
    public class bookDaoImple implements bookDao{
      //注入JdbcTemplate
      @Autowired
      private JdbcTemplate jdbcTemplate;
       
    //查询返回查询返回一个数据集合(整张表) 
	@Override
    public List<book> selectAll() {
        String sql = "select * from book";
        List<book> bookList = jdbcTemplate.query(sql, new BeanPropertyRowMapper<book>(book.class));
        return bookList;
    }
}

//3.编写service类
@Service
public class bookService {

    //1.注入dao
    @Autowired
    private bookDao bookdao;

   //查询返回一个集合(返回整张表)
    public List<book> findAllbook(){
        return bookdao.selectAll();
    }

}

//4.编写测试类
        List<book> allbook = bookservice.findAllbook();
        System.out.println(allbook);
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Spring JdbcTemplateSpring框架提供的一个对JDBC进行封装的工具类,它可以简化JDBC编程的复杂性,提供了一种更简便的方式来访问数据库JdbcTemplate的原理是将JDBC的访问进行封装,提供了一些常用的操作方法,例如查询、更新、批量操作等。它通过DataSource来获取JDBC的连接,并通过Connection对象进行JDBC的操作,最后释放连接资源。 使用JdbcTemplate进行数据库操作的步骤如下: 1. 配置数据源,配置JdbcTemplate。 2. 在代码中通过JdbcTemplate对象进行数据库操作。 下面是一个简单的例子: 配置数据源和JdbcTemplate: ```xml <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource"> <property name="driverClassName" value="com.mysql.jdbc.Driver"/> <property name="url" value="jdbc:mysql://localhost:3306/test"/> <property name="username" value="root"/> <property name="password" value="root"/> </bean> <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate"> <property name="dataSource" ref="dataSource"/> </bean> ``` 在代码中通过JdbcTemplate对象进行数据库操作: ```java @Autowired private JdbcTemplate jdbcTemplate; public void insertUser(User user) { String sql = "INSERT INTO user(name, age) VALUES(?, ?)"; jdbcTemplate.update(sql, user.getName(), user.getAge()); } public List<User> getUsers() { String sql = "SELECT * FROM user"; List<User> users = jdbcTemplate.query(sql, new BeanPropertyRowMapper<>(User.class)); return users; } ``` 在上面的代码中,我们通过@Autowired注解注入了JdbcTemplate对象,并使用它来执行插入和查询操作。 通过JdbcTemplate,我们可以使用占位符来传递参数,也可以使用BeanPropertyRowMapper将查询结果映射为Java对象。 总的来说,Spring JdbcTemplate的原理是封装了JDBC的访问,提供了一种更便捷的方式来操作数据库

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值