详解jdbcTemplate和namedParameterJdbcTemplate
来源:互联网 发布:外国在线视频下载软件 编辑:程序博客网 时间:2024/06/12 19:32
我们开发DAO层时用的最多的就是ORM框架(Mybatis,hibernate)了。在有些特殊的情况下,ORM框架的搭建略显笨重,这时最好的选择就是Spring中的jdbcTemplate了。本文对jdbcTemplate进行详解,并且会对具名参数namedParameterJdbcTemplate进行讲解。
jdbcTemplate讲解
jdbcTemplate提供的主要方法:
- execute方法:可以用于执行任何SQL语句,一般用于执行DDL语句;
- update方法及batchUpdate方法:update方法用于执行新增、修改、删除等语句;batchUpdate方法用于执行批处理相关语句;
- query方法及queryForXXX方法:用于执行查询相关语句;
- call方法:用于执行存储过程、函数相关语句。
jdbcTemplate环境搭建:
1 在spring配置文件中加上jdbcTemplate的bean:
<!--注入jdbcTemplate--> <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate"> <property name="dataSource" ref="dataSource"/> </bean>
注意:在这之前我们需要先配置好数据库数据源dateSource。
2.在使用jdbcTemplate类中使用@Autowired进行注入
@Autowired private JdbcTemplate jdbcTemplate;
jdbcTemplate方法测试:
我们准备一个数据库
准备数据库对应的实体pojo,实体的名称都要对应数据库的字段名称:
public class User { private Long id; private String username; private String password; public Long getId() { return id; } public void setId(Long id) { this.id = id; } public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } @Override public String toString() { return "User{" + "id=" + id + ", username='" + username + '\'' + ", password='" + password + '\'' + '}'; }}
1.查询单个对象queryForObject:
@Test public void testQuery(){ String sql = "select id,username,password from user where id=?"; BeanPropertyRowMapper<User> rowMapper = new BeanPropertyRowMapper<User>(User.class); User user = jdbcTemplate.queryForObject(sql, rowMapper,1); System.out.println(user); }
输出结果: User{id=1, username=’123’, password=’123’}
2.查询多个对象query:
@Test public void testMutiQuery(){ String sql = "select id,username,password from user"; BeanPropertyRowMapper<User> rowMapper = new BeanPropertyRowMapper<User>(User.class); List<User> users = jdbcTemplate.query(sql, rowMapper); for (User user : users) { System.out.println(user); } }
输出结果:
User{id=1, username=’123’, password=’123’}
User{id=2, username=’1234’, password=’1234’}
3.查询count、avg、sum等函数返回唯一值:
@Test public void testCountQuery(){ String sql = "select count(*) from user"; BeanPropertyRowMapper<User> rowMapper = new BeanPropertyRowMapper<User>(User.class); Integer result = jdbcTemplate.queryForObject(sql, Integer.class); System.out.println(result); }
输出结果:2
4.增删改方法测试:
新增:
@Test public void testCreate(){ String sql = "insert into user (username,password) values (?,?)"; int create = jdbcTemplate.update(sql, new Object[]{255, 255}); System.out.println(create); }
输出结果为1,去数据库查看也确实插入这条。
修改:
@Test public void testUpdate(){ String sql = "update user set username=? , password=? where id=?"; int update = jdbcTemplate.update(sql, new Object[]{256, 256,3}); System.out.println(update); }
输出结果为1,并且确实数据已经修改
删除:
@Test public void testDelete(){ String sql = "delete from user where id=?"; int delete = jdbcTemplate.update(sql, new Object[]{3}); System.out.println(delete); }
5.批量操作:
@Test public void testBatch(){ List<Object[]> batchArgs=new ArrayList<Object[]>(); batchArgs.add(new Object[]{777,888}); batchArgs.add(new Object[]{666,888}); batchArgs.add(new Object[]{555,888}); String sql = "insert into user (username,password) values (?,?)"; jdbcTemplate.batchUpdate(sql, batchArgs); }
以上方法基本满足了日常我们多DAO层进行的操作,不过当你进行CRUD操作时如果传入的参数不确定,这时候你可能会想起ORM框架的便利。没关系!Spring也为我们提供了这样的操作NamedParameterJdbcTemplate。
NamedParameterJdbcTemplate讲解
在经典的 JDBC 用法中, SQL 参数是用占位符 ? 表示,并且受到位置的限制. 定位参数的问题在于, 一旦参数的顺序发生变化, 就必须改变参数绑定.
在 Spring JDBC 框架中, 绑定 SQL 参数的另一种选择是使用具名参数(named parameter).
那么什么是具名参数?
具名参数: SQL 按名称(以冒号开头)而不是按位置进行指定. 具名参数更易于维护, 也提升了可读性. 具名参数由框架类在运行时用占位符取代
具名参数只在 NamedParameterJdbcTemplate 中得到支持。NamedParameterJdbcTemplate可以使用全部jdbcTemplate方法,除此之外,我们来看看使用它的具名参数案例:
具名新增:
@Test public void testNamedParameter(){ String sql = "insert into user (username,password) values (:username,:password)"; User u = new User(); u.setUsername("555"); SqlParameterSource sqlParameterSource=new BeanPropertySqlParameterSource(u); namedParameterJdbcTemplate.update(sql,sqlParameterSource); }
我们来看看结果
这样我们就可以根据pojo类的属性值使用JDBC来操作数据库了。
获取新增的主键:
NamedParameterJdbcTemplate还新增了KeyHolder类,使用它我们可以获得主键,类似Mybatis中的useGeneratedKeys。
@Test public void testKeyHolder(){ String sql = "insert into user (username,password) values (:username,:password)"; User u = new User(); u.setUsername("555"); SqlParameterSource sqlParameterSource=new BeanPropertySqlParameterSource(u); KeyHolder keyHolder = new GeneratedKeyHolder(); namedParameterJdbcTemplate.update(sql, sqlParameterSource, keyHolder); int k = keyHolder.getKey().intValue(); System.out.println(k); }
输出结果就是新增的主键。
参考资料
- Spring JdbcTemplate详解
- Spring框架笔记(二十五)——NamedParameterJdbcTemplate与具名参数
- 使用Spring的NamedParameterJdbcTemplate完成DAO操作
本文作者: catalinaLi
本文链接: http://catalinali.top/2017/useJDBC/
版权声明: 原创文章,有问题请评论中留言。非商业转载请注明作者及出处。
- 详解jdbcTemplate和namedParameterJdbcTemplate
- spring的JdbcTemplate、NamedParameterJdbcTemplate和SimpleJdbcTemplate
- Spring NamedParameterJdbcTemplate 详解 解决jdbcTemplate中 in 参数的问题
- Spring_23-24使用 JdbcTemplate和JdbcDaoSupport和NamedParameterJdbcTemplate
- Spring配置JDBCTemplate连接数据库、JDBCTemplate和NamedParameterJdbcTemplate常用操作示例
- JdbcTemplate 、NamedParameterJdbcTemplate、SimpleJdbcTemplate的区别
- JdbcTemplate 、NamedParameterJdbcTemplate、SimpleJdbcTemplate的区别
- JdbcTemplate 、NamedParameterJdbcTemplate、SimpleJdbcTemplate的区别
- Spring的JdbcTemplate、NamedParameterJdbcTemplate、SimpleJdbcTemplate
- Spring的JdbcTemplate、NamedParameterJdbcTemplate、SimpleJdbcTemplate
- Spring的JdbcTemplate、NamedParameterJdbcTemplate、SimpleJdbcTemplate
- Spring的JdbcTemplate、NamedParameterJdbcTemplate、SimpleJdbcTemplate
- JdbcTemplate 、NamedParameterJdbcTemplate、SimpleJdbcTemplate的区别
- 好记性不如烂笔头101-spring3(21)-jdbcTemplate和NamedParameterJdbcTemplate的小差异
- Jdbctemplate NamedParameterJdbcTemplate实现关键字IN 预编译
- Spring NamedParameterJdbcTemplate 详解
- Spring NamedParameterJdbcTemplate 详解
- Spring中NamedParameterJdbcTemplate详解
- 线段树总结
- postgresql数据库使用函数查询所有符合条件的表名,以及删除所有查询到的表的数据
- org.openqa.selenium.NoSuchElementException: Unable to locate element: 异常解决方法
- [.cpp]挑战程序设计问题的利器 freopen()函数
- Airflow 初试
- 详解jdbcTemplate和namedParameterJdbcTemplate
- MyEclipse10和MyEclipse2014项目之间的导入
- FZU-2254 英语考试
- Shape Correspondence and Functional Maps
- C++类与对象——日期类
- Lucene查询索引
- Android 使用RecyclerView实现列表item重叠效果(使用addItemDecoration方法)
- IO多路复用
- HDU 6180 && 2017 多校训练:Schedule