JdbcTemplate主要提供以下五类方法:

execute方法:可以用于执行任何SQL语句,一般用于执行DDL语句;

update方法及batchUpdate方法:update方法用于执行新增、修改、删除等语句;batchUpdate方法用于执行批处理相关语句;

query方法及queryForXXX方法:用于执行查询相关语句;

call方法:用于执行存储过程、函数相关语句。

JdbcTemplate类支持的回调类:

预编译语句及存储过程创建回调:用于根据JdbcTemplate提供的连接创建相应的语句;

PreparedStatementCreator:通过回调获取JdbcTemplate提供的Connection,由用户使用该Conncetion创建相关的PreparedStatement;

CallableStatementCreator:通过回调获取JdbcTemplate提供的Connection,由用户使用该Conncetion创建相关的CallableStatement;

预编译语句设值回调:用于给预编译语句相应参数设值;

PreparedStatementSetter:通过回调获取JdbcTemplate提供的PreparedStatement,由用户来对相应的预编译语句相应参数设值;

BatchPreparedStatementSetter:;类似于PreparedStatementSetter,但用于批处理,需要指定批处理大小;

自定义功能回调:提供给用户一个扩展点,用户可以在指定类型的扩展点执行任何数量需要的操作;

ConnectionCallback:通过回调获取JdbcTemplate提供的Connection,用户可在该Connection执行任何数量的操作;

StatementCallback:通过回调获取JdbcTemplate提供的Statement,用户可以在该Statement执行任何数量的操作;

PreparedStatementCallback:通过回调获取JdbcTemplate提供的PreparedStatement,用户可以在该PreparedStatement执行任何数量的操作;

CallableStatementCallback:通过回调获取JdbcTemplate提供的CallableStatement,用户可以在该CallableStatement执行任何数量的操作;

结果集处理回调:通过回调处理ResultSet或将ResultSet转换为需要的形式;

RowMapper:用于将结果集每行数据转换为需要的类型,用户需实现方法mapRow(ResultSet rs, int rowNum)来完成将每行数据转换为相应的类型。

RowCallbackHandler:用于处理ResultSet的每一行结果,用户需实现方法processRow(ResultSet rs)来完成处理,在该回调方法中无需执行rs.next(),该操作由JdbcTemplate来执行,用户只需按行获取数据然后处理即可。

ResultSetExtractor:用于结果集数据提取,用户需实现方法extractData(ResultSet rs)来处理结果集,用户必须处理整个结果集;

1: JdbcTemplate

1.1 query

单个对象

/**
* 处理单个对象
*/
@Test
public void test_1() {
JdbcTemplate jdbcTemplate = new JdbcTemplate(JDBCUtils.getDataSource());
String sql = "select * from student where id=1"; Student student = jdbcTemplate.query(sql, new ResultSetExtractor<Student>() {
@Override
public Student extractData(ResultSet res) throws SQLException, DataAccessException {
Student student = null;
while (res.next()) {
int id = res.getInt("id");
String name = res.getString("name");
boolean gender = res.getBoolean("gender");
Date birthday = res.getDate("birthday");
student = new Student(id, name, gender, birthday);
}
return student;
}
});
System.out.println(student);
}
@Test
public void test_2() {
JdbcTemplate jdbcTemplate = new JdbcTemplate(JDBCUtils.getDataSource());
String sql = "select * from student where id=1";
// 这里演示RowCallbackHandler 上面也可以使用函数式写法 不能返回
jdbcTemplate.query(sql, (res)-> {
String name = res.getString("name");
System.out.println(name);
});
}
@Test
public void test_3() {
JdbcTemplate jdbcTemplate = new JdbcTemplate(JDBCUtils.getDataSource());
String sql = "select * from student where id=1";
Student stu = jdbcTemplate.query(sql, (res)->{
Student student = null;
while (res.next()) {
int id = res.getInt("id");
String name = res.getString("name");
boolean gender = res.getBoolean("gender");
Date birthday = res.getDate("birthday");
student = new Student(id, name, gender, birthday);
}
return student;
});
System.out.println(stu);
}
//聚集函数
@Test
public void test_4() {
JdbcTemplate jdbcTemplate = new JdbcTemplate(JDBCUtils.getDataSource());
String sql = "select count(*) from student";
Integer inx = jdbcTemplate.queryForObject(sql, Integer.class);
System.out.println(inx);
} @Test
public void test_5() {
JdbcTemplate jdbcTemplate = new JdbcTemplate(JDBCUtils.getDataSource());
String sql = "select id from student";
List<Integer> list = jdbcTemplate.queryForList(sql, Integer.class);
}

List Map

    /**
* 处理单个对象
*/
@Test
public void test_1() {
JdbcTemplate jdbcTemplate = new JdbcTemplate(JDBCUtils.getDataSource());
String sql = "select * from student where id=1"; Student student = jdbcTemplate.query(sql, new ResultSetExtractor<Student>() {
@Override
public Student extractData(ResultSet res) throws SQLException, DataAccessException {
Student student = null;
while (res.next()) {
int id = res.getInt("id");
String name = res.getString("name");
boolean gender = res.getBoolean("gender");
Date birthday = res.getDate("birthday");
student = new Student(id, name, gender, birthday);
}
return student;
}
});
System.out.println(student);
}
@Test
public void test_2() {
JdbcTemplate jdbcTemplate = new JdbcTemplate(JDBCUtils.getDataSource());
String sql = "select * from student where id=1";
// 这里演示RowCallbackHandler 上面也可以使用函数式写法 不能返回
jdbcTemplate.query(sql, (res)-> {
String name = res.getString("name");
System.out.println(name);
});
}
@Test
public void test_3() {
JdbcTemplate jdbcTemplate = new JdbcTemplate(JDBCUtils.getDataSource());
String sql = "select * from student where id=1";
Student stu = jdbcTemplate.query(sql, (res)->{
Student student = null;
while (res.next()) {
int id = res.getInt("id");
String name = res.getString("name");
boolean gender = res.getBoolean("gender");
Date birthday = res.getDate("birthday");
student = new Student(id, name, gender, birthday);
}
return student;
});
System.out.println(stu);
}
//聚集函数
@Test
public void test_4() {
JdbcTemplate jdbcTemplate = new JdbcTemplate(JDBCUtils.getDataSource());
String sql = "select count(*) from student";
Integer inx = jdbcTemplate.queryForObject(sql, Integer.class);
System.out.println(inx);
} @Test
public void test_5() {
JdbcTemplate jdbcTemplate = new JdbcTemplate(JDBCUtils.getDataSource());
String sql = "select id from student";
List<Integer> list = jdbcTemplate.queryForList(sql, Integer.class);
}

1.2 upadte  

@Test
public int insertUser(Student stu) {
JdbcTemplate jdbcTemplate = new JdbcTemplate(JDBCUtils.getDataSource());
String sql = "insert into student values(null,?,?,?)";
return jdbcTemplate.update(sql, new Object[] { stu.getName(), stu.isGender(), stu.getBirthday() });
} @Test
public int delete(int id) {
JdbcTemplate jdbcTemplate = new JdbcTemplate(JDBCUtils.getDataSource());
String sql = "delete from student where id=?";
return jdbcTemplate.update(sql, 1);
}

2:NamedParameterJdbcTemplate

  使用与JdbcTemplate 最大的区别就是 使用命名符号来代表占位符? 使SQl 容易理解  但是 代码量增加了,取舍在于个人

    @Test
public void findById() {
NamedParameterJdbcTemplate template = new NamedParameterJdbcTemplate(JDBCUtils.getDataSource());
String sql="select * FROM student where name like (:regxp)";
/*
* jdbctemplate 用?站位
* NamedParameterJdbcTemplate : 使用:xxx 站位 通过hashmap 写入参数
* map:
* String:参数名称
* Object:参数值
*/
HashMap<String, Object> paMap = new HashMap<>();
paMap.put("regxp", "%");
BeanPropertyRowMapper<Student> rowMapper = new BeanPropertyRowMapper<>(Student.class);
List<Student> list = template.query(sql,paMap, rowMapper);
System.out.println(list);
} @Test
public void insert_Stu() {
NamedParameterJdbcTemplate template = new NamedParameterJdbcTemplate(JDBCUtils.getDataSource());
String sql="insert into student(name,gender,birthday) values(:name,:gender,:birthday)";
HashMap<String, Object> paramMap = new HashMap<>();
paramMap.put("name", "如来佛祖");
paramMap.put("gender", "1");
paramMap.put("birthday", "2019-2-2");
if(template.update(sql, paramMap)>0) {
System.out.println("true");
}
}

Spring提供JdbcTemplate&NamedParameterJdbcTemplate的更多相关文章

  1. spring3: 对JDBC的支持 之 Spring提供的其它帮助 SimpleJdbcInsert/SimpleJdbcCall/SqlUpdate/JdbcTemplate 生成主键/批量处理

    7.4  Spring提供的其它帮助 7.4.1  SimpleJdbc方式 Spring JDBC抽象框架提供SimpleJdbcInsert和SimpleJdbcCall类,这两个类通过利用JDB ...

  2. 开涛spring3(7.4) - 对JDBC的支持 之 7.4 Spring提供的其它帮助

    7.4  Spring提供的其它帮助 7.4.1  SimpleJdbc方式 Spring JDBC抽象框架提供SimpleJdbcInsert和SimpleJdbcCall类,这两个类通过利用JDB ...

  3. spring: 使用Spring提供的JDBC模板(使用profiles选择数据源/使用基于JDBC驱动的数据源)

    Spring提供的JDBC框架负责管理资源和异常处理,从而可以简化开发者的JDBC代码.开发者只需要编写写入和读取数据库相关的代码即可. 正如在之前的小节中论述过的,Spring将数据库访问过程中的模 ...

  4. Spring利用JDBCTemplate实现批量插入和返回id

    1.先介绍一下java.sql.Connection接口提供的三个在执行插入语句后可取的自动生成的主键的方法: //第一个是 PreparedStatement prepareStatement(St ...

  5. spring使用jdbcTemplate和jdbcdaosupport和namedparameter

    jdbcTemplate: 首先连接数据库 <!-- 导入外部文件 --> <context:property-placeholder location="classpat ...

  6. spring和jdbctemplate

    1.spring与jdbc整合应用 a.增删改 -获取connection -获取statement -设置sql中?参数 -执行sql操作 -释放connection b.查询 -获取connect ...

  7. Spring之JDBCTemplate学习

    一.Spring对不同的持久化支持: Spring为各种支持的持久化技术,都提供了简单操作的模板和回调 ORM持久化技术 模板类 JDBC org.springframework.jdbc.core. ...

  8. spring+spring mvc+JdbcTemplate 入门小例子

    大家使用这个入门时候 最好能够去 搜一下 spring mvc 的 原理,我放一张图到这里,自己琢磨下,后面去学习就容易了 给个链接 (网上一把,千万不能懒)    https://www.cnblo ...

  9. spring 学习(四): spring 的 jdbcTemplate 操作

    spring 学习(四): spring 的 jdbcTemplate 操作 spring 针对 javaee 的每一层,都提供了相应的解决技术,jdbcTemplate 的主要操作在 dao 层. ...

随机推荐

  1. pycharm报错:Process finished with exit code -1073741819 (0xC0000005)解决办法

    这个是几个月前的问题了,有小伙伴在CSDN问我咋解决的,那我今天在这边把这个问题解决办法分享下吧,免得大家把很多时间都浪费在安装排坑上面,有些坑虽然解决了还真不知道啥原因. 我的pycharm一直用的 ...

  2. javascript---简介的切换图片效果。

    <!--切换图片--> <img src="img/9.gif" alt="" id="img"> <butt ...

  3. MySQL数据库解决大数据量存储问题

    转载自:https://www.cnblogs.com/ryanzheng/p/8334915.html 提问:如何设计或优化千万级别的大表?此外无其他信息,个人觉得这个话题有点范,就只好简单说下该如 ...

  4. Bandizip解压压缩软件

    上次重装系统以后,特别注意安装软件,在这里提一些比较好的 解压软件:Bandizip 这个是一个免费轻量级的软件,压缩解压速度快,没什么广告,推荐大家在官方下载 Bandizip下载网址 点击下载安装 ...

  5. 第05组 Beta版本演示

    第05组 Beta版本演示 小组信息 组名:天码行空 组长博客:地址 组内成员: 组员 学号 卢欢(组长) 031702513 陈天恒 031702527 古力亚尔·艾山 031702511 张聪 0 ...

  6. IT兄弟连 HTML5教程 CSS3揭秘 CSS常见的样式属性和值5

    CSS综合实例 在Web页面中经常使用栏目显示分类内容.本例将使用HTML和CSS结合编写一个分类栏目模型,用于演示前面介绍的CSS应用.通过使用独立的文件定义样式表,并在HTML文档中使用link标 ...

  7. react+ant-mobile+lib-flexible构建移动端项目适应设计图尺寸(750)

    使用lib-flexible在react中先安装 npm install lib-flexible --save 因为插件使用的是rem适配,所以安装两个插件 npm install postcss- ...

  8. SpringBoot入门(简单详细教程)

    Spring Boot 简介 简化Spring应用开发的一个框架:整个Spring技术栈的一个大整合:J2EE开发的一站式解决方案: 微服务 martin fowler:微服务:架构风格(服务微化): ...

  9. aop分层模型——aop是元编程的一种

    织入应用层—->待织入的附加功能 应用层 织入管理层—->使用元语和织入的功能进行编程 语言层 aop元语层---〉aop机制提供的高阶抽象概念. 解释层 aop引擎层—->维护的实 ...

  10. ES6-Set的增加、查找、删除、遍历、查看长度、数组去重

    set 是es6新出的一种数据结构,里边放的是数组. 作用:去重(set里边的数组不能重复) MDN:Set 对象允许你存储任何类型的唯一值,无论是原始值或者是对象引用. 总结: 1.成员唯一.无序且 ...