当前位置: 首页 > news >正文

jdbc模板的基本使用

1.JdbcTemplate的开发步骤

        <1>导入spring-jdbc和spring-tx坐标

        <2>创建数据库表和实体

        <3>创建JdbcTemplate对象

        <4>执行数据库

2.JdbcTemplate快速入门

        <1>导入坐标

        

<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>

        <2>创建实体类和表

package com.lin.domain;public class Account {private String name;private double money;public Account() {}public Account(String name, double money) {this.name = name;this.money = money;}public String getName() {return name;}public double getMoney() {return money;}public void setName(String name) {this.name = name;}public void setMoney(double money) {this.money = money;}@Overridepublic String toString() {return "Account{" +"name='" + name + '\'' +", money=" + money +'}';}
}

 <3>创建jdbcTemplate对象

<4>执行数据库操作

@Test//测试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("123456");JdbcTemplate jdbcTemplate=new JdbcTemplate();//设置数据源对象,知道数据库在哪jdbcTemplate.setDataSource(dataSource);//执行操作int row = jdbcTemplate.update("insert into account value (?,?)", "wu", 12);System.out.println(row);}

3.spring 产生jdbcTemplate对象

可以将数据源DateSource的创建权交给Spring,在Spring容器内部将数据源注入到模板中

spring容器加载外部properties文件时必须添加context命名空间

 <!--加载properties文件 添加context命名空间--><context:property-placeholder location="classpath:jdbc.properties"/><!--配置数据源对象--><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>

4.crud操作

package com.lin.test;import com.lin.domain.Account;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.BeanPropertyRowMapper;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;import java.util.List;@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration("classpath:applicationContext.xml")
public class CrudTest {@Autowired
//    测试谁注入谁private JdbcTemplate jdbcTemplate;@Testpublic void testUpdate(){int row = jdbcTemplate.update("update account set money=? where name=?", 100000, "ws");System.out.println(row);}@Testpublic void testDelete(){int row = jdbcTemplate.update("delete from account where name=?",  "ws");System.out.println(row);}//查询所有@Testpublic void testQueryAll(){List<Account> list = jdbcTemplate.query("select *from account", new BeanPropertyRowMapper<Account>(Account.class));System.out.println(list);}@Test//单个查询时返回一个对象public void testQueryOne(){Account account = jdbcTemplate.queryForObject("select * from account where name=?", new BeanPropertyRowMapper<Account>(Account.class), "wu");System.out.println(account);}//聚合查询@Testpublic void testQueryCount(){Long count = jdbcTemplate.queryForObject("select count(*) from account", Long.class);System.out.println(count);}
}

5.小节

① 导入spring-jdbc和spring-tx坐标
② 创建数据库表和实体
③ 创建JdbcTemplate对象
        JdbcTemplate jdbcTemplate = new JdbcTemplate();
        jdbcTemplate.setDataSource(dataSource);
④ 执行数据库操作
        更新操作:
        jdbcTemplate.update (sql,params)
        查询操作:
        jdbcTemplate.query (sql,Mapper,params)
        jdbcTemplate.queryForObject(sql,Mapper,params)
http://www.lryc.cn/news/22123.html

相关文章:

  • JPA 注解及主键生成策略使用指南
  • 【C语言刷题】找单身狗、模拟实现atoi
  • 前端必会面试题指南
  • C 语言—— 数组
  • Oracle-RAC集群主机重启问题分析
  • Python每日一练(20230227)
  • Scratch少儿编程案例-算法练习-存款收益计算
  • 【Linux驱动开发100问】Linux驱动开发工程师在面试中常被问到的问题汇总
  • 每日学术速递2.27
  • 【数据库系统概论】基础知识总结
  • 简单移动平均在量化中的应用(附Python实战代码)
  • ChatGPT提高你日常工作的五个特点,以及如何使用它来提高代码质量
  • spark datasourceV1和v2
  • 10种聚类算法的完整python操作示例
  • 构建合作伙伴生态系统刻不容缓
  • 剑指 Offer 55 - I. 二叉树的深度(java解题)
  • 威胁行为者将旧漏洞武器化以发起勒索软件攻击
  • 2023北京健博会/第十届中国国际大健康产博览会
  • Python学习笔记之环境搭建
  • 死锁的总结
  • 强化学习RL 01~ 数学基础
  • Java的运算符
  • 扫地机器人(蓝桥杯C/C++)
  • 如何理解API?API 是如何工作的?(5分钟诠释)
  • PAT--1111 对称日
  • 前端纯函数和副作用概念,且在react上的体现详解
  • 转行软件测试3年了,听前辈说测试前途是IT里最low的,我慌了......
  • CNI 网络流量 5.1 Cilium 介绍和原理
  • 机加行业MES解决方案,助力企业打造数字化透明车间
  • C/C++每日一练(20230227)