jdbcTemplate

JDBCTemplate模版

概述

Spring JDBC Spring框架对JDBC的简单封装。提供了一个JDBCTemplate对象简化JDBC的开发

实现步骤

1. 导入jar包 4 + 1

2. 创建JdbcTemplate对象。依赖于数据源DataSource
	JdbcTemplate template = new JdbcTemplate(ds);

3. 调用JdbcTemplate的方法来完成CRUD的操作
	update():执行DML语句。增、删、改语句
	queryForMap():查询结果将结果集封装为map集合,将列名作为key,将值作为value 将这条记录封装为一个map集合
			注意:这个方法查询的结果集长度只能是1
	queryForList():查询结果将结果集封装为list集合
			注意:将每一条记录封装为一个Map集合,再将Map集合装载到List集合中
	query():查询结果,将结果封装为JavaBean对象
			query的参数:RowMapper
			一般我们使用BeanPropertyRowMapper实现类。可以完成数据到JavaBean的自动封装
			new BeanPropertyRowMapper<类型>(类型.class)
			queryForObject:查询结果,将结果封装为对象
			一般用于聚合函数的查询

快速入门

/**
 * JdbcTemplate入门
 */
public class JdbcTemplateDemo1 {
    public static void main(String[] args) {
        //1.导入jar包
        //2.创建JDBCTemplate对象
        JdbcTemplate template = new JdbcTemplate(JDBCUtils.getDataSource());
        //3.调用方法
        String sql = "update account set balance = 5000 where id = ?";
        int count = template.update(sql, 3);//insert update delete	
        System.out.println(count);
        //自已关闭,自已归还
    }
}

CRUD的测试

代码实现

数据库准备

CREATE TABLE `emp` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `username` varchar(25) DEFAULT NULL,
  `job` varchar(100) DEFAULT NULL,
  `addr` varchar(25) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

INSERT INTO `test`.`emp`(`id`, `username`, `job`, `addr`) VALUES (1, 'tom', '开发', '上海');
INSERT INTO `test`.`emp`(`id`, `username`, `job`, `addr`) VALUES (2, 'mary', '测试', '郑州');

实体类

// 注意事项:java属性名   要与   数据库的字段名保持一致,不然无法封装
public class Emp {
    private Integer id;
    private String username;
    private String job;
    private String addr;
    //提供有参无对构造方法
    //提供get  set 方法
    //提供toString方法
}

测试类

public class Test1 {

    //获取数据源
    private DataSource dataSource = JDBCUtil.getDataSource();
    //使用jdbcTemplate 技术,简化jdbc操作
    private JdbcTemplate JdbcTemplate = new JdbcTemplate(dataSource);

    //修改
    @Test
    public void testUpdateById(){
        String sql ="update emp set job = '财务' where id = ? ";
        int i = this.JdbcTemplate.update(sql, 2);
        System.out.println(i);
    }

    //添加
    @Test
    public void testAdd(){
        String sql ="insert into emp (id , username , job ,addr) values(?,?,?,?)";
        int i = JdbcTemplate.update(sql, null, "yiyan", "小秘", "郑州");
        System.out.println(i);
    }
    //删除
    @Test
    public void testDeleteById(){
        String sql ="delete from emp where id = ?";
        int i = JdbcTemplate.update(sql, 1);
        System.out.println(i);
    }

    //查询数据返回list
    @Test
    public void testQueryById(){
        String sql ="select * from emp where id = ?";
        //返回的是list
        List<Emp> emps = this.JdbcTemplate.query(sql, new BeanPropertyRowMapper<>(Emp.class), 2);
        for(Emp e : emps){
            System.out.println(e);
        }
    }

    //查询条数
    @Test
    public void testForObject(){
        String sql = "select count(1) from emp";
        Long i = this.JdbcTemplate.queryForObject(sql, Long.class);
        System.out.println(i);
    }

    //查询数据返回map
    @Test
    public void testQuery2(){
        String sql = "select * from emp where id = ?";
        //返回map
        Map<String, Object> map = this.JdbcTemplate.queryForMap(sql,2);
        //map遍历
        Set<String> set = map.keySet();
        for(String key : set){
            Object o = map.get(key);
            System.out.println(key+" : "+o);
        }
    }
    
     /**
     * 查询数据返回对象中
     * 注意事项: 返回的单个对象必须要有结果,这个结果只能接受一条
     *           
     */
    public  Emp queryTest3(){
        Emp emp = null;
        try {
            String sql = "select * from emp where id = ?";
            //如果这里查到数据,就直接返回
            return this.template.queryForObject(sql, new BeanPropertyRowMapper<>(Emp.class),9);
        } catch (DataAccessException e) {
            //没有查询到,方式一
            // throw new RuntimeException("没有查询到数据!");
            //没有查询到,方式二
            return null;
        }
    }
	//测试 查询数据返回对象中
    public static void main(String[] args) {
        JdbcTemplateDemo jt = new JdbcTemplateDemo();
        Emp emp = jt.queryTest3();
        System.out.println(emp);
    }
    
    
}

你可能感兴趣的:(开发语言)