一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - Java Spring JdbcTemplate基本使用詳解

Java Spring JdbcTemplate基本使用詳解

2022-03-02 12:49龍弟-idea Java教程

JDBC已經能夠滿足大部分用戶最基本的需求,但是在使用JDBC時,必須自己來管理數據庫資源如:獲取PreparedStatement,設置SQL語句參數,關閉連接等步驟

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

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 欧美午夜视频一区二区 | 香蕉久久高清国产精品免费 | 12一14性水蜜桃 | 探花国产 | 欧美怡红院视频一区二区三区 | 3d欧美人与禽交 | 成人欧美一区二区三区 | 全肉np巨肉一女np高h双龙 | 香蕉eeww99国产精选播放 | 亚洲成在人线视频 | 亚洲上最大成网人站4438 | 黄瓜视频黄 | 精品国产免费第一区二区 | ffyybb免费福利视频 | ova催眠性指导5最新在线 | 四虎成人免费视频 | 日本中文字幕一区二区有码在线 | 无套暴躁白丝秘书 | 99久久国产综合精品网成人影院 | 韩国伊人 | 好逼365| 国产午夜不卡 | 火影忍者小南裸羞羞漫画 | 丝袜白浆 | 喘息揉弄1v1h老师 | 亚洲国产第一区二区香蕉日日 | 欧美黑人一级片 | 别停好爽好深好大好舒服视频 | 国色天香高清版 | 国产在线观看精品 | 免费岛国| 亚洲国产网址 | 国产123区| 欧洲肥女大肥臀tv | a亚洲天堂 | 蜜色影院 | 日日操日日舔 | 四虎永久在线精品免费影视 | 洗濯屋し在线观看 | 亚洲精品αv一区二区三区 亚洲精品91大神在线观看 | 亚州一区二区 |