一、Spring JDBC

Spring JDBC是在JDBC API的基础上定义一个抽象层,用以简化JDBC操作。Spring JdbcTemplate是Spring JDBC框架的核心,为不同类型的JDBC操作提供模板方法,每个模板方法都能控制整个过程,并允许覆盖过程中的特定任务。基于此,可以在保留灵活性的情况下,将数据库存取的工作量降到最低。

二、Bean配置

在Spring配置文件中,配置一个Spring JdbcTemplate Bean:

   <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate"><property name="dataSource" ref="dataSource"/></bean>

三、准备测试数据

登录mysql,创建一张用于测试的数据表:

create database testdb;
use testdb

创建一张数据表:

CREATE TABLE `user` (`uid` int(1) NOT NULL AUTO_INCREMENT,`username` varchar(50) NOT NULL,`password` varchar(200) NOT NULL,PRIMARY KEY (`uid`)
) ENGINE=InnoDB AUTO_INCREMENT=8 DEFAULT CHARSET=utf8;

四、JdbcTemplate提供的常用方法

import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import org.springframework.jdbc.core.BeanPropertyRowMapper;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.RowMapper;import javax.sql.DataSource;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;/*** Created by bee on 17/5/17.*/public class JDBCTest {private ApplicationContext ctx = null;private JdbcTemplate jdbcTemplate;{ctx = new ClassPathXmlApplicationContext("beans-jdbc.xml");jdbcTemplate = (JdbcTemplate) ctx.getBean("jdbcTemplate");}/**** @throws SQLException*/@Testpublic void TestDataSource() throws SQLException {DataSource dataSource = ctx.getBean(DataSource.class);System.out.println(dataSource.getConnection());}/***更新属性*/@Testpublic void updateTest() {String sql = "UPDATE user SET username = ? WHERE uid = ?";jdbcTemplate.update(sql, "神乐", 2);}/***插入数据*/@Testpublic void insertTest() {String sql = "INSERT user(username,password) values('Tonny','123456')";jdbcTemplate.execute(sql);}/***删除记录*/@Testpublic void deleteTest() {String sql = "DELETE FROM user where uid = ?";jdbcTemplate.update(sql, 3);}/***批量插入*/@Testpublic void batchUpdateTest() {String sql = "INSERT INTO user(username,password) values(?,?)";List<Object[]> batchArgs = new ArrayList<Object[]>();batchArgs.add(new Object[]{"Tina", "876543"});batchArgs.add(new Object[]{"Judy", "587641"});batchArgs.add(new Object[]{"Sam", "987632"});jdbcTemplate.batchUpdate(sql, batchArgs);}/***查询*/@Testpublic void queryForObject() {String sql = "SELECT uid AS id,username AS userName,password AS passWord " +"FROM user WHERE uid = ?";RowMapper<User> rowMapper = new BeanPropertyRowMapper<User>(User.class);User user = (User) jdbcTemplate.queryForObject(sql, rowMapper, 2);System.out.println(user);}/***批量查询*/@Testpublic void queryForList() {String sql = "SELECT uid AS id,username AS userName,password AS passWord FROM user WHERE uid > ?";RowMapper<User> rowMapper = new BeanPropertyRowMapper<User>(User.class);List<User> users = jdbcTemplate.query(sql, rowMapper, 3);System.out.println(users);}/***统计*/@Testpublic void countTest() {String sql = "SELECT COUNT(*) FROM user";long count = jdbcTemplate.queryForObject(sql, Long.class);System.out.println(count);}}

Spring全家桶(九)Spring JdbcTemplate相关推荐

  1. spring3.x企业应用开发实战 pdf_吃透Spring全家桶:Spring源码+SpringBoot+SpringCloud实战...

    一.Spring技术内幕 深入解析Spring架构与设计原理 本书探讨了Spring框架的设计原理.架构和运行机制.作为在Java领域最为成功的开源软件之一,Spring在Java EE开发中,使用者 ...

  2. osgi框架和spring区别_最全153道Spring全家桶面试题,你都知道哪些?(含答案解析)...

    前言 Spring 框架自诞生以来一直备受开发者青睐,有人亲切的称之为:Spring 全家桶. 毋庸置疑,Spring 早已成为 Java 后端开发的行业标准,无数的公司选择 Spring 作为基础的 ...

  3. mybatis中文文档_成神之路!缓存+MyBatis+MySQL+Spring全家桶+分布式技术实战合集

    最近花了很长的时间去搜罗Java核心技术好文,我把每个Java核心技术的优选文章都整理成了一个又一个的文档.昨天也是终于全部整理好了,今天就把这些东西分享给老铁们,也能为老铁们省去不少麻烦,想学什么技 ...

  4. 这是我见过最完整的Spring全家桶学习笔记,没有之一!

    耗时将近一个月,终于赶在金九银十,学完了Spring全家桶系列.梳理了下整个过程,总结了一套经验和学习方法,分享给有需要的各位. 首先说一下,为什么我要花这么多时间,下功夫来恶补Spring全家桶? ...

  5. 知乎热搜,最全1184页Spring全家桶面试资料库,学习完大厂offer随你挑

    前言 Spring 框架自诞生以来一直备受开发者青睐,有人亲切的称之为:Spring 全家桶. 毋庸置疑,Spring 早已成为 Java 后端开发的行业标准,无数的公司选择 Spring 作为基础的 ...

  6. Spring全家桶及思维导图

    目录 前言 Spring Framework的思维导图 Spring MVC的思维导图 Spring Boot的思维导图 Spring Cloud的思维导图 总结 前言 spring系列的框架作为老牌 ...

  7. 2022 年精选架构合集:Redis+Nginx+ 设计模式 +Spring 全家桶 +Dubbo

    最近花了很长的时间去搜罗 Java 核心技术好文,我把每个 Java 核心技术的优选文章都整理成了一个又一个的文档.昨天也是终于全部整理好了,今天就把这些东西分享给老铁们,也能为老铁们省去不少麻烦,想 ...

  8. Redis+Nginx+ 设计模式 +Spring 全家桶 +Dubbo 技术精选合集

    最近花了很长的时间去搜罗 Java 核心技术好文,我把每个 Java 核心技术的优选文章都整理成了一个又一个的文档.昨天也是终于全部整理好了,今天就把这些东西分享给老铁们,也能为老铁们省去不少麻烦,想 ...

  9. 2022年精选架构合集:Redis+Nginx+设计模式+Spring全家桶+Dubbo

    最近花了很长的时间去搜罗Java核心技术好文,我把每个Java核心技术的优选文章都整理成了一个又一个的文档.昨天也是终于全部整理好了,今天就把这些东西分享给老铁们,也能为老铁们省去不少麻烦,想学什么技 ...

最新文章

  1. Spring MVC+Spring+MyBatis实现支付宝扫码支付功能(图文详解)
  2. 51单片机的定时器深入讲解
  3. Reverse digits of an integer
  4. RGB图像中值平滑和均值平滑
  5. Ubuntu20.04+i3wm折腾笔记
  6. 贪吃蛇贪吃蛇代码--c语言版 visual c++6.0打开
  7. smplayer变成电视操作步骤
  8. 51单片机小车—循迹温湿度检测显示
  9. 控制教程 —— 介绍篇:6.状态空间控制器设计
  10. 金蝶如何用计算机,金蝶软件要换电脑用,该怎么处理?
  11. 阿里云云解析DNS怎么样?云解析DNS有什么优势?
  12. c语言算兔子野鸡,“上山兔子下山鸡,离水甲鱼不要追”,有什么科学依据?...
  13. php抢票程序,python并发编程多进程 模拟抢票实现过程
  14. java 开发工具eli_二进制开发ELI5 –第1部分
  15. Java的Modifier
  16. 每个人心中都有一个Eumenides
  17. 软件测试常见的问题概略
  18. 读书笔记-在工作中保持充沛的体力
  19. Android基础整合项目之节日群发助手(二)
  20. 爬取凤凰网站财经类的新闻,函数时编程,可全部实现,由于内容量大,需要时间太长,服务器会禁止,为了防止,可以将time.sleep()设置的时间长点...

热门文章

  1. 关于SWOT,你了解多少?
  2. 编码的奥秘:图形化革命
  3. 《放学后》《解忧杂货店》《等风来》读后感
  4. 计算机上电自检的作用,电脑每次开机都自检的几种解决方法
  5. 【牛客网】邮票;python set()集合函数,去重;“”、“|”、“-”求并集、交集、差集
  6. 自考本科毕业后还有必要专升本读全日制本科吗?
  7. 短信收到的发票链接打不开解决办法
  8. 【Spring Security OAuth2笔记系列】- Spring Social第三方登录 - QQ登录下
  9. Linux下帆软报表部署
  10. 读书笔记:Classification Beats Regression: Counting of Cells from Greyscale Microscopic Images based on A