Spring NamedParameterJdbcTemplate 详解 解决jdbcTemplate中 in 参数的问

自己的例子:

List<String> l = new ArrayList<String>();
		l.add("2549");l.add("2959");
		NamedParameterJdbcTemplate namedParameterJdbcTemplate = null;
		//namedParameterJdbcTemplate =
//		    new NamedParameterJdbcTemplate(dataSource);
		namedParameterJdbcTemplate =
		new NamedParameterJdbcTemplate(dbUtil.getJdbcTemplate());
		  Map<String, Object> paramMap = new HashMap<String, Object>();
		    paramMap.put("deptIds", l);
		String sql = "select z.dept_id,z.sid from z_docs_catalog z "
				+ "where z.state = 1 and z.flag = ‘000‘and z.dept_id in (:deptIds)";
		List<Map<String,Object>> result = namedParameterJdbcTemplate.queryForList(sql, paramMap);

NamedParameterJdbcTemplate类是基于JdbcTemplate类,并对它进行了封装从而支持命名参数特性。

NamedParameterJdbcTemplate主要提供以下三类方法:execute方法、query及queryForXXX方法、update及batchUpdate方法。

首先让我们看个例子吧:

java代码:

Java代码  

  1. @Test
  2. public void testNamedParameterJdbcTemplate1() {
  3. NamedParameterJdbcTemplate namedParameterJdbcTemplate = null;
  4. //namedParameterJdbcTemplate =
  5. //    new NamedParameterJdbcTemplate(dataSource);
  6. namedParameterJdbcTemplate =
  7. new NamedParameterJdbcTemplate(jdbcTemplate);
  8. String insertSql = "insert into test(name) values(:name)";
  9. String selectSql = "select * from test where name=:name";
  10. String deleteSql = "delete from test where name=:name";
  11. Map<String, Object> paramMap = new HashMap<String, Object>();
  12. paramMap.put("name", "name5");
  13. namedParameterJdbcTemplate.update(insertSql, paramMap);
  14. final List<Integer> result = new ArrayList<Integer>();
  15. namedParameterJdbcTemplate.query(selectSql, paramMap,
  16. new RowCallbackHandler() {
  17. @Override
  18. public void processRow(ResultSet rs) throws SQLException {
  19. result.add(rs.getInt("id"));
  20. }
  21. });
  22. Assert.assertEquals(1, result.size());
  23. SqlParameterSource paramSource = new MapSqlParameterSource(paramMap);
  24. namedParameterJdbcTemplate.update(deleteSql, paramSource);
  25. }

接下来让我们分析一下代码吧:

1)NamedParameterJdbcTemplate初始化:可以使用DataSource或JdbcTemplate 对象作为构造器参数初始化;

2)insert into test(name) values(:name):其中“:name”就是命名参数;

3) update(insertSql, paramMap):其中paramMap是一个Map类型,包含键为“name”,值为“name5”的键值对,也就是为命名参数设值的数据;

4)query(selectSql, paramMap, new RowCallbackHandler()……):类似于JdbcTemplate中介绍的,唯一不同是需要传入paramMap来为命名参数设值;

5)update(deleteSql, paramSource):类似于“update(insertSql, paramMap)”,但使用SqlParameterSource参数来为命名参数设值,此处使用MapSqlParameterSource实现,其就是简单封装java.util.Map。

NamedParameterJdbcTemplate类为命名参数设值有两种方式:java.util.Map和SqlParameterSource:

1)java.util.Map:使用Map键数据来对于命名参数,而Map值数据用于设值;

2)SqlParameterSource:可以使用SqlParameterSource实现作为来实现为命名参数设值,默认有MapSqlParameterSource和BeanPropertySqlParameterSource实现;MapSqlParameterSource实现非常简单,只是封装了java.util.Map;而BeanPropertySqlParameterSource封装了一个JavaBean对象,通过JavaBean对象属性来决定命名参数的值。

java代码:

Java代码  

  1. package cn.javass.spring.chapter7;
  2. public class UserModel {
  3. private int id;
  4. private String myName;
  5. //省略getter和setter
  6. }

java代码:

Java代码  

  1. @Test
  2. public void testNamedParameterJdbcTemplate2() {
  3. NamedParameterJdbcTemplate namedParameterJdbcTemplate = null;
  4. namedParameterJdbcTemplate = new NamedParameterJdbcTemplate(jdbcTemplate);
  5. UserModel model = new UserModel();
  6. model.setMyName("name5");
  7. String insertSql = "insert into test(name) values(:myName)";
  8. SqlParameterSource paramSource = new BeanPropertySqlParameterSource(model);
  9. namedParameterJdbcTemplate.update(insertSql, paramSource);
  10. }

可以看出BeanPropertySqlParameterSource使用能减少很多工作量,但命名参数必须和JavaBean属性名称相对应才可以。

再分享一下我老师大神的人工智能教程吧。零基础!通俗易懂!风趣幽默!还带黄段子!希望你也加入到我们人工智能的队伍中来!https://blog.csdn.net/jiangjunshow

原文地址:https://www.cnblogs.com/skinchqqhah/p/10349838.html

时间: 2024-10-10 02:08:51

Spring NamedParameterJdbcTemplate 详解 解决jdbcTemplate中 in 参数的问的相关文章

Spring NamedParameterJdbcTemplate详解

NamedParameterJdbcTemplate和JdbcTemplate功能基本差不多.使用方法也类型.下面具体看下代码. db.properties 1 jdbc.user=root 2 jdbc.password=123456 3 jdbc.driverClass=com.mysql.jdbc.Driver 4 jdbc.jdbcUrl=jdbc\:mysql\:///test applicationContext.xml 1 <?xml version="1.0" e

Spring NamedParameterJdbcTemplate详解(10)

NamedParameterJdbcTemplate和JdbcTemplate功能基本差不多.使用方法也类型.下面具体看下代码. db.properties 1 jdbc.user=root 2 jdbc.password=123456 3 jdbc.driverClass=com.mysql.jdbc.Driver 4 jdbc.jdbcUrl=jdbc\:mysql\:///test applicationContext.xml 1 <?xml version="1.0" e

详解Http请求中Content-Type讲解以及在Spring MVC中的应用

详解Http请求中Content-Type讲解以及在Spring MVC中的应用 引言: 在Http请求中,我们每天都在使用Content-type来指定不同格式的请求信息,但是却很少有人去全面了解content-type中允许的值有多少,这里将讲解Content-Type的可用值,以及在spring MVC中如何使用它们来映射请求信息. 1.  Content-Type MediaType,即是Internet Media Type,互联网媒体类型:也叫做MIME类型,在Http协议消息头中,

Spring JDBC详解

<Spring JDBC详解> 本文旨在讲述Spring JDBC模块的用法.Spring JDBC模块是Spring框架的基础模块之一. 作者:chszs,转载需注明.博客主页:http://blog.csdn.net/chszs 一.概述 在Spring JDBC模块中,所有的类可以被分到四个单独的包:1)core即核心包,它包含了JDBC的核心功能.此包内有很多重要的类,包括:JdbcTemplate类.SimpleJdbcInsert类,SimpleJdbcCall类,以及NamedP

Spring AOP详解(转载)

此前对于AOP的使用仅限于声明式事务,除此之外在实际开发中也没有遇到过与之相关的问题.最近项目中遇到了以下几点需求,仔细思考之后,觉得采用AOP 来解决.一方面是为了以更加灵活的方式来解决问题,另一方面是借此机会深入学习Spring AOP相关的内容.本文是权当本人的自己AOP学习笔记,以下需求不用AOP肯定也能解决,至于是否牵强附会,仁者见仁智者见智. 对部分函数的调用进行日志记录,用于观察特定问题在运行过程中的函数调用情况 监控部分重要函数,若抛出指定的异常,需要以短信或邮件方式通知相关人员

Spring AOP 详解 【转】

此前对于AOP的使用仅限于声明式事务,除此之外在实际开发中也没有遇到过与之相关的问题.最近项目中遇到了以下几点需求,仔细思考之后,觉得采用AOP 来解决.一方面是为了以更加灵活的方式来解决问题,另一方面是借此机会深入学习Spring AOP相关的内容.本文是权当本人的自己AOP学习笔记,以下需求不用AOP肯定也能解决,至于是否牵强附会,仁者见仁智者见智. 对部分函数的调用进行日志记录,用于观察特定问题在运行过程中的函数调用情况 监控部分重要函数,若抛出指定的异常,需要以短信或邮件方式通知相关人员

细说Spring——AOP详解(动态代理实现AOP)

前言 嗯,我应该是有一段实现没有写过博客了,在写完了细说Spring——AOP详解(AOP概览)之后,我发现我不知道该怎么写AOP这一部分,所以就把写博客这件事给放下了,但是这件事情又不想就这么放弃,所以今天我仔细思考了一下,决定还是要克服困难,我仔细的想了一下怎么讲解AOP实现这一部分,然后我决定由浅入深的讲解动态代理,然后用动态代理实现一个简单的AOP,感觉这样能够让人对AOP的原理有一个比较深刻的认识,希望能帮到大家.而且最近学习又组建了ACM比赛的队伍,虽然已经要大三了,按理来说应该一心

C语言 realloc为什么要有返回值,realloc返回值详解/(解决任意长度字符串输入问题)。

在C语言操作中会用到大量的内存操作,其中很常用的一个是realloc(). 由字面意思可以知道,该函数的作用是用于重新分配内存. 使用方式如下: NewPtr=(数据类型*)realloc(OldPtr,MemSize) 其中OldPtr指向 待重新分配内存的指针. NewPtr指向 新分配空间的指针. MemSize为 分配后的空间大小. 该函数的使用涉及以下几个问题: 1.不同情况下的返回值 2.OldPtr指向的内存会不会自动释放 3.OldPtr和NewPtr分别是什么内容,他们有什么关

Spring AOP详解(转载)所需要的包

上一篇文章中,<Spring Aop详解(转载)>里的代码都可以运行,只是包比较多,中间缺少了几个相应的包,根据报错,几经百度搜索,终于补全了所有包. 截图如下: 在主测试类里面,有人怀疑,没有main方法,是怎么运行的.这是用的junit,结合spring来进行的测试类. Spring AOP详解(转载)所需要的包,布布扣,bubuko.com