-
我们都知道要使用数据库需要导入jdbc包,然后需要自己写一下连接资源,增删改查封装,开关闭连接等等,这些其实都是固定的操作,改变的只是SQL的变化。
-
JdbcTemplate呢,就由此而生,JdbcTemplate帮我们把这些固定的操作到进行了封装,也就是不需要我们进行连接关闭数据库,我们只需要关注SQL执行业务就行了,是不是很方便呢?那如何使用呢?
-
我是在SpringBoot的环境下执行的,首先就需要在maven中导入JdbcTemplate的依赖,相当于是导入jar包。
-
导入依赖以后,为了让JdbcTemplate能够找到数据库的配置信息,需要在应用配置文件中配置数据库的信息。以下是我做松松过考试系统的基础配置。
- 系统已经帮我们注入好了JTP(缩写了,懒),我们只需要在需要执行数据库操作的时候进行自动装备(SpringBoot学习笔记中已介绍)取值JTP对象就行了。
- 例如:
@Autowired JdbcTemplate jdbcTemplate; //这里就是获取了jdbcTemplate对象 /*** * 添加用户 * @param user * @return 是否成功 */ public boolean addUser(Users user) { int flag = jdbcTemplate.update("CALL pro_addUser(?,?,?,?)", new Object[]{user.getU_name(),user.getU_gender(),user.getU_wxid(),user.getU_pwd()}); System.out.println(flag); return flag >= 1 ? true : false; //返回的是受影响行数 } //然后在测试类中进行了测试 @Autowired public JdbcTemplate jdbcTemplate; @Autowired @Qualifier("getUser") private Users user; //这里是获取了配置bean @Autowired @Qualifier("getUserDao") private UserDao userDao; //获取dao @Test void contextLoads() { user.setU_name("何夜息"); user.setU_gender(1); user.setU_wxid("1545"); user.setU_pwd("4874974"); boolean s = userDao.addUser(user); System.out.println(s); }
- 数据库存储成功:
- 需要说下为什么不用excute()方法添加,因为我用后发现这个方法没有返回值,那我为了方便知道我添加是否成功,所有用了update,效果是一样的,这个方法返回的受影响的行数,就能判断是否操作成功啦。
查询
- 增删改的操作是一样的,最后来了解下查询。
- 网上呢,需要一般都是实现了RowMapper接口,也就是把从数据库获取的值,通过封装,返回一个对象实体类。
- 这里就不实现接口了,直接使用方法queryForXXX,一般都是Object省心省肺。
@Test void contextLoads() { String sql = "SELECT count(*) FROM users;"; Integer c = jdbcTemplate.queryForObject(sql,Integer.class); System.out.println(c); }
- 我数据库只有一条记录,自然就是1,查询成功。
- 查询一行的时候,用map来接收。
Map<String,Object> u = jdbcTemplate.queryForMap("SELECT * FROM users where u_name='何夜息'");
for(Object o:u.values())
{
System.out.println(o);
}
2020-05-16 14:49:05.699 INFO 7096 --- [ main] com.zaxxer.hikari.HikariDataSource : HikariPool-1 - Start completed.
1
何夜息
1
1545
271f5ca5d4396ff7cf891ae3ef77c12b
2020-05-16 21:44:39.0
- 现在来查询下多行数据,可以用两种方法来实现:
- 第一种使用最原始SqlRowSet,简单实现一下
SqlRowSet rs = jdbcTemplate.queryForRowSet("select * from users"); //这里获取一个行集合
while (rs.next()) //遍历
{
System.out.println(rs.getString("u_name")); //通过字段输出
System.out.println(rs.getString("u_pwd"));
}
- 输出内容如下
2020-05-16 14:57:58.831 INFO 5388 --- [ main] com.zaxxer.hikari.HikariDataSource : HikariPool-1 - Start completed.
何夜息
271f5ca5d4396ff7cf891ae3ef77c12b
和
d1qw6d4qw4d89qw74d98q4wd984wqd94
成龙
646496496r83234r23424
- 还有一种是QueryForList,返回一个链表,这就需要理解数据结构,也就是一张链表里面,有多个Map集合,一个map集合就是一行数据,也就是链表包含了map集合。如下是源码:
public List<Map<String, Object>> queryForList(String sql) throws DataAccessException {
return this.query(sql, this.getColumnMapRowMapper());
}
- 现在开始测试:
List<Map<String,Object>> ls = jdbcTemplate.queryForList("SELECT * FROM users");
for(Map o:ls)
{
System.out.println(o);
}
- 运行结果如下,要去直接输出了map,可以自己单个取值,确实取出了多个map值。
2020-05-16 15:08:28.132 INFO 11392 --- [ main] com.zaxxer.hikari.HikariDataSource : HikariPool-1 - Start completed.
{u_id=1, u_name=何夜息, u_gender=1, u_wxid=1545, u_pwd=271f5ca5d4396ff7cf891ae3ef77c12b, u_rdate=2020-05-16 21:44:39.0}
{u_id=3, u_name=和, u_gender=0, u_wxid=00000, u_pwd=d1qw6d4qw4d89qw74d98q4wd984wqd94, u_rdate=2020-05-15 22:50:26.0}
{u_id=4, u_name=成龙, u_gender=1, u_wxid=00000, u_pwd=646496496r83234r23424, u_rdate=2020-05-07 22:56:00.0}
好了,到这里基本可以去实践了,码代码去咯,拜拜!!!!