简叙JdbcTemplate

  • 我们都知道要使用数据库需要导入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}

好了,到这里基本可以去实践了,码代码去咯,拜拜!!!!

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值