服务器之家

服务器之家 > 正文

Java Spring JdbcTemplate基本使用详解

时间:2022-03-02 12:49     来源/作者:龍弟-idea

JdbcTemplate概述

它是spring框架中提供的一个对象,是对原始繁琐的Jdbc API对象的简单封装。spring框架为我们提供了很多的操作模板类。例如:操作关系型数据的JdbcTemplate和HibernateTemplate,操作nosql数据库的RedisTemplate,操作消息队列的JmsTemplate等等。

JdbcTemplate开发步骤

①导入spring-jdbc和spring-tx坐标
②创建数据库表和实体
③创建JdbcTemplate对象
④执行数据库操作

JdbcTemplate快速入门

①导入spring-jdbc和spring-tx坐标

  <dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-jdbc</artifactId>
    <version>5.0.5.RELEASE</version>
  </dependency>
  <dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-tx</artifactId>
    <version>5.0.5.RELEASE</version>
  </dependency>

②创建accout表和Accout实体

Java Spring JdbcTemplate基本使用详解

public class Account {

  private String name;
  private double money;

  public String getName() {
      return name;
  }

  public void setName(String name) {
      this.name = name;
  }

  public double getMoney() {
      return money;
  }

  public void setMoney(double money) {
      this.money = money;
  }

  @Override
  public String toString() {
      return "Account{" +
              "name='" + name + '\'' +
              ", money=" + money +
              '}';
  }
}

③创建JdbcTemplate对象

④执行数据库操作

  //测试JdbcTemplate开发步骤
  public void test1() throws PropertyVetoException {
      //创建数据源对象
      ComboPooledDataSource dataSource = new ComboPooledDataSource();
      dataSource.setDriverClass("com.mysql.jdbc.Driver");
      dataSource.setJdbcUrl("jdbc:mysql://localhost:3306/test");
      dataSource.setUser("root");
      dataSource.setPassword("root");

      JdbcTemplate jdbcTemplate = new JdbcTemplate();
      //设置数据源对象  知道数据库在哪
      jdbcTemplate.setDataSource(dataSource);
      //执行操作
      int row = jdbcTemplate.update("insert into account values(?,?)", "tom", 5000);
      System.out.println(row);

  }

Spring产生JdbcTemplate对象

我们可以将JdbcTemplate的创建权交给Spring,将数据源DataSource的创建权也交给Spring,在Spring容器内部将数据源DataSource注入到JdbcTemplate模版对象中,配置如下:

  <!--数据源对象-->
  <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
      <property name="driverClass" value="${jdbc.driver}"/>
      <property name="jdbcUrl" value="${jdbc.url}"/>
      <property name="user" value="${jdbc.username}"/>
      <property name="password" value="${jdbc.password}"/>
  </bean>
  <!--jdbc模板对象-->
  <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
      <property name="dataSource" ref="dataSource"/>
  </bean>

从容器中获得JdbcTemplate进行添加操作

  //测试Spring产生jdbcTemplate对象
  public void test2() throws PropertyVetoException {
      ApplicationContext app = new ClassPathXmlApplicationContext("applicationContext.xml");
      JdbcTemplate jdbcTemplate = app.getBean(JdbcTemplate.class);
      jdbcTemplate.update("insert into account values(?,?)", "lisi", 5000);
      System.out.println(row);
  }

JdbcTemplate的常用操作

修改操作、删除和查询全部操作

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration("classpath:applicationContext.xml")
public class JdbcTemplateCRUDTest {

  @Autowired
  private JdbcTemplate jdbcTemplate;

  @Test
  public void testQueryCount(){
      Long count = jdbcTemplate.queryForObject("select count(*) from account", Long.class);
      System.out.println(count);
  }

  @Test
  public void testQueryOne(){
      Account account = jdbcTemplate.queryForObject("select * from account where name=?", new BeanPropertyRowMapper<Account>(Account.class), "tom");
      System.out.println(account);
  }

  @Test
  public void testQueryAll(){
      List<Account> accountList = jdbcTemplate.query("select * from account", new BeanPropertyRowMapper<Account>(Account.class));
      System.out.println(accountList);
  }

  @Test
  public void testUpdate(){
      jdbcTemplate.update("update account set money=? where name=?",10000,"tom");
  }

  @Test
  public void testDelete(){
      jdbcTemplate.update("delete from account where name=?","tom");
  }

}

到此这篇关于Java Spring JdbcTemplate基本使用详解的文章就介绍到这了,更多相关Java Spring JdbcTemplate内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/weixin_48838340/article/details/120874857

标签:

相关文章

热门资讯

2022年最旺的微信头像大全 微信头像2022年最新版图片
2022年最旺的微信头像大全 微信头像2022年最新版图片 2022-01-10
蜘蛛侠3英雄无归3正片免费播放 蜘蛛侠3在线观看免费高清完整
蜘蛛侠3英雄无归3正片免费播放 蜘蛛侠3在线观看免费高清完整 2021-08-24
背刺什么意思 网络词语背刺是什么梗
背刺什么意思 网络词语背刺是什么梗 2020-05-22
yue是什么意思 网络流行语yue了是什么梗
yue是什么意思 网络流行语yue了是什么梗 2020-10-11
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全 2019-12-26
返回顶部