Spring JdbcTemplate

文章源码

JdbcTemplate 概述

它是 Spring 框架中提供的一个对象,是对原始 Jdbc API 对象的简单封装。Spring 框架提供了很多的操作模板类。

操作关系型数据的:JdbcTemplate、HibernateTemplate

操作 NoSQL 数据库的:RedisTemplate

操作消息队列的:JmsTemplate

要使用 JdbcTemplate,需要 spring-jdbc 包。

JdbcTemplate CRUD

bean.xml:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans
https://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
https://www.springframework.org/schema/context/spring-context.xsd"> <context:component-scan base-package="cn.parzulpan"/> <!-- 添加继承 JdbcDaoSupport 的实现类到容器,并注入 jdbcTemplate-->
<bean id="accountDAO2" class="cn.parzulpan.dao.AccountDAOImpl2">
<property name="jdbcTemplate" ref="jdbcTemplate"/>
</bean> <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
<property name="dataSource" ref="dataSource"/>
</bean> <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/springT?useSSL=false"/>
<property name="username" value="root"/>
<property name="password" value="root"/>
</bean> </beans>

JdbcTemplate 对象的创建和基本使用:

package cn.parzulpan;

import org.springframework.context.support.ClassPathXmlApplicationContext;
import org.springframework.jdbc.core.JdbcTemplate; /**
* @Author : parzulpan
* @Time : 2020-12
* @Desc : JdbcTemplate 对象的创建和基本使用
*/ public class JdbcTemplateTest {
public static void main(String[] args) {
ClassPathXmlApplicationContext ac = new ClassPathXmlApplicationContext("bean.xml");
JdbcTemplate jt = ac.getBean("jdbcTemplate", JdbcTemplate.class);
jt.execute("insert into bankAccount(name, money) values ('caf', 25415.6)");
}
}

AccountDAOImpl.java

package cn.parzulpan.dao;

import domain.Account;
import org.springframework.jdbc.core.BeanPropertyRowMapper;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.stereotype.Repository; import javax.annotation.Resource;
import java.util.List; /**
* @Author : parzulpan
* @Time : 2020-12
* @Desc : 账户持久层实现类,这种方式即可以实现注解配置,也可以使用 xml 配置
*/ @Repository("accountDAO")
public class AccountDAOImpl implements AccountDAO {
@Resource(name = "jdbcTemplate")
JdbcTemplate jdbcTemplate; @Override
public List<Account> findAll() {
return jdbcTemplate.query("select * from bankAccount",
new BeanPropertyRowMapper<>(Account.class));
} @Override
public Account findById(Integer id) {
List<Account> accounts = jdbcTemplate.query("select * from bankAccount where id = ?",
new BeanPropertyRowMapper<>(Account.class),
id);
return accounts.isEmpty() ? null : accounts.get(0);
} @Override
public Account findByName(String name) {
List<Account> accounts = jdbcTemplate.query("select * from bankAccount where name = ?",
new BeanPropertyRowMapper<>(Account.class),
name);
if (accounts.isEmpty()) {
return null;
} if (accounts.size() > 1) {
throw new RuntimeException("结果集不唯一!");
} return accounts.get(0);
} @Override
public void update(Account account) {
jdbcTemplate.update("update bankAccount set name = ? , money = ? where id = ?",
account.getName(), account.getMoney(), account.getId());
} @Override
public void insert(Account account) {
jdbcTemplate.update("insert into bankAccount(name, money) values (?, ?)",
account.getName(), account.getMoney());
} @Override
public void delete(Integer id) {
jdbcTemplate.update("delete from bankAccount where id = ?",
id);
} @Override
public Long getCount() {
return jdbcTemplate.queryForObject("select count(*) from bankAccount;",
Long.class);
}
}

AccountDAOImpl2.java

package cn.parzulpan.dao;

import domain.Account;
import org.springframework.jdbc.core.BeanPropertyRowMapper;
import org.springframework.jdbc.core.support.JdbcDaoSupport;
import org.springframework.stereotype.Repository; import java.util.List; /**
* @Author : parzulpan
* @Time : 2020-12
* @Desc : 账户持久层实现类,继承 JdbcDaoSupport
*
* JdbcDaoSupport 是 Spring 框架提供的一个类,该类中定义了一个 JdbcTemplate 对象,
* 可以直接获取使用,但是要想创建该对象,需要为其提供一个数据源。
*
* 这种的好处是当有很多个 DAO 时,不需要注入很多 jdbcTemplate
*
* 注意:这种方式只能使用 xml 配置,因为 JdbcDaoSupport 中已经定义了 jdbcTemplate,且提供其 setter
*/ public class AccountDAOImpl2 extends JdbcDaoSupport implements AccountDAO {
@Override
public List<Account> findAll() {
return super.getJdbcTemplate().query("select * from bankAccount",
new BeanPropertyRowMapper<>(Account.class));
} @Override
public Account findById(Integer id) {
List<Account> accounts = getJdbcTemplate().query("select * from bankAccount where id = ?",
new BeanPropertyRowMapper<>(Account.class),
id);
return accounts.isEmpty() ? null : accounts.get(0);
} @Override
public Account findByName(String name) {
List<Account> accounts = getJdbcTemplate().query("select * from bankAccount where name = ?",
new BeanPropertyRowMapper<>(Account.class),
name);
if (accounts.isEmpty()) {
return null;
} if (accounts.size() > 1) {
throw new RuntimeException("结果集不唯一!");
} return accounts.get(0);
} @Override
public void update(Account account) {
getJdbcTemplate().update("update bankAccount set name = ? , money = ? where id = ?",
account.getName(), account.getMoney(), account.getId());
} @Override
public void insert(Account account) {
getJdbcTemplate().update("insert into bankAccount(name, money) values (?, ?)",
account.getName(), account.getMoney());
} @Override
public void delete(Integer id) {
getJdbcTemplate().update("delete from bankAccount where id = ?",
id);
} @Override
public Long getCount() {
return getJdbcTemplate().queryForObject("select count(*) from bankAccount;",
Long.class);
}
}

AccountDAOImplTest.java

package cn.parzulpan.dao;

import domain.Account;
import org.junit.Test;
import org.springframework.context.support.ClassPathXmlApplicationContext; import java.util.List; /**
* @Author : parzulpan
* @Time : 2020-12
* @Desc : 账户持久层实现类的测试
*/ public class AccountDAOImplTest {
ClassPathXmlApplicationContext ac = new ClassPathXmlApplicationContext("bean.xml");
// AccountDAO ad = ac.getBean("accountDAO1", AccountDAO.class);
AccountDAO ad = ac.getBean("accountDAO2", AccountDAO.class); @Test
public void findAll() {
List<Account> accounts = ad.findAll();
for (Account account : accounts) {
System.out.println(account);
}
} @Test
public void findById() {
Account account = ad.findById(1);
System.out.println(account);
} @Test
public void findByName() {
Account account = ad.findByName("aaa");
System.out.println(account);
} @Test
public void update() {
ad.update(new Account(6, "update", 214.0));
} @Test
public void insert() {
ad.insert(new Account(99, "insert", 3125616.425));
} @Test
public void delete() {
ad.delete(7);
} @Test
public void getCount() {
Long count = ad.getCount();
System.out.println(count);
}
}

总结和练习

【Spring】Spring JdbcTemplate的更多相关文章

  1. 【转】spring - ioc和aop

    [转]spring - ioc和aop 1.程序中为什么会用到spring的ioc和aop 2.什么是IOC,AOP,以及使用它们的好处,即详细回答了第一个问题 3.原理 关于1: a:我们平常使用对 ...

  2. 【Spring】Spring随笔索引

    Spring随笔索引 [Spring]Spring bean的实例化 [Spring]手写Spring MVC [Spring]Spring Data JPA

  3. 【转】Spring总结以及在面试中的一些问题

    [转]Spring总结以及在面试中的一些问题. 1.谈谈你对spring IOC和DI的理解,它们有什么区别? IoC Inverse of Control 反转控制的概念,就是将原本在程序中手动创建 ...

  4. 【转】Spring学习---Spring IoC容器的核心原理

    [原文] Spring的两个核心概念:IoC和AOP的雏形,Spring的历史变迁和如今的生态帝国. IoC和DI的基本概念 IoC(控制反转,英文含义:Inverse of Control)是Spr ...

  5. 【原】Spring整合Redis(第二篇)—SDR环境搭建具体步骤

    [环境参数] Spring版本:4.2.6.RELEASESpring-Data-Redis版本:1.7.2.RELEASE Redis版本:redis-2.4.5-win32-win64 [简要说明 ...

  6. 【转】Spring中事务与aop的先后顺序问题

    [原文链接] http://my.oschina.net/HuifengWang/blog/304188 [正文] Spring中的事务是通过aop来实现的,当我们自己写aop拦截的时候,会遇到跟sp ...

  7. 【目录】Spring 源码学习

    [目录]Spring 源码学习 jwfy 关注 2018.01.31 19:57* 字数 896 阅读 152评论 0喜欢 9 用来记录自己学习spring源码的一些心得和体会以及相关功能的实现原理, ...

  8. 【进阶】Spring中的注解与反射

    [进阶]Spring中的注解与反射 目录 [进阶]Spring中的注解与反射 前言 一.内置(常用)注解 1.1@Overrode 1.2@RequestMapping 1.3@RequestBody ...

  9. 【转载】Spring JdbcTemplate详解

    JdbcTemplate简介 Spring对数据库的操作在jdbc上面做了深层次的封装,使用spring的注入功能,可以把DataSource注册到JdbcTemplate之中. JdbcTempla ...

  10. 【Spring】Spring的数据库开发 - 1、Spring JDBC的配置和Spring JdbcTemplate的解析

    Spring JDBC 文章目录 Spring JDBC Spring JdbcTemplate的解析 Spring JDBC的配置 简单记录-Java EE企业级应用开发教程(Spring+Spri ...

随机推荐

  1. Java经典小游戏——贪吃蛇简单实现(附源码)

    一.使用知识 Jframe GUI 双向链表 线程 二.使用工具 IntelliJ IDEA jdk 1.8 三.开发过程 3.1素材准备 首先在开发之前应该准备一些素材,已备用,我主要找了一个图片以 ...

  2. Eclipse的基本设置与使用

    下载完eclipse后,还不能立即来写代码,需要完成一些必要的设置 设置 1.对整个工作区设置编码格式 选择菜单栏中的"Window"选项,然后选择"Preference ...

  3. elementUI的动态tabs页的使用,vue的动态组件的操作

    elementUI的动态tabs页的使用,vue的动态组件的操作 有时候我们需要用到动态的tab页,结合不同的页面内容来显示.这里是使用了elementUI的动态tabs页来实现的 <div c ...

  4. HBase数据导入导出工具

    hbase中自带一些数据导入.导出工具 1. ImportTsv直接导入 1.1 hbase中建表 create 'testtable4','cf1','cf2' 1.2 准备数据文件data.txt ...

  5. css进阶 03-网页设计和开发中,关于字体的常识

    03-网页设计和开发中,关于字体的常识 #前言 我周围的码农当中,有很多是技术大神,却常常被字体这种简单的东西所困扰. 这篇文章,我们来讲一讲关于字体的常识.这些常识所涉及到的问题,有很强的可操作性, ...

  6. 2020年“感恩杯”台州学院第十三届大学生程序设计竞赛D、H、I题解(后续补充)

    D题:小z与他的袜子 描述 小z每天会穿一双新袜子. 开始他的衣柜里有n双袜子,袜子会从1-n进行编号.每天早上他都会从衣柜里拿编号最小的袜子来穿.每天晚上他会把今天穿的袜子扔进篮子里,如果篮子里有n ...

  7. iOS label 添加删除线(删划线)遇到的坑

    1.添加删划线方法遇到的问题 -(void)lastLabelDeal:(NSString *)str1 string:(NSString *)str2 label:(UILabel *)label{ ...

  8. SVN 使用教程 命令 visual studio 使用SVN

    首先推荐大家一个应该是国内外最好的SVN仓库,不限私有,不限成员:https://svnbucket.com/ SVN官网 https://tortoisesvn.net/downloads.html ...

  9. IIS安装 URL Rewrite Module 2.1

    短地址http://www.iis.net/extensions/URLRewrite 下载页面https://www.iis.net/downloads/microsoft/url-rewrite# ...

  10. springclud中附件上传

    package org.springblade.desk.controller; import com.baomidou.mybatisplus.core.metadata.IPage; import ...