Tecnología de encapsulación de bases de datos JDBCTemplate

1. ¿Qué es la plantilla JDBC?

La conexión de la base de datos, la liberación de recursos, la adición, eliminación, consulta y modificación requieren escribir mucho código repetitivo y complicado. El marco Spring ha realizado una encapsulación simple de JDBC. Proporciona un objeto JDBCTemplate para simplificar el desarrollo de JDBC.

Por ejemplo, el siguiente método de transferencia:

1. Antes de usar jdbctemplate:

public boolean Money(String fromName,String toName,double money){
        Connection conn = null;
        PreparedStatement preparedStatement1 = null;
        PreparedStatement preparedStatement2 = null;
        try {
            conn = JDBCUtils.getConnection();
            conn.setAutoCommit(false);                       //开启事务
            String sql1 = "update db1.account set balance = balance - ? where name = ?";
            String sql2 = "update db1.account set balance = balance + ? where name = ?";
            preparedStatement1 = conn.prepareStatement(sql1);
            preparedStatement2 = conn.prepareStatement(sql2);
            preparedStatement1.setDouble(1,money);
            preparedStatement1.setString(2,fromName);
            preparedStatement2.setDouble(1,money);
            preparedStatement2.setString(2,toName);
            preparedStatement1.executeUpdate();
            preparedStatement2.executeUpdate();
            conn.commit();                           //提交事务
        } catch (Exception e) {
            try {
                if(conn != null)
                    conn.rollback();                   //若发生异常则回滚事务
            } catch (SQLException ex) {
                ex.printStackTrace();
                return false;
            }
            e.printStackTrace();
            return false;
        }finally {
            JDBCUtils.close(preparedStatement1,conn);
            JDBCUtils.close(preparedStatement2,null);
        }
        return true;
}

2. Después de usar jdbctemplate: 

public boolean Money(String fromName,String toName,double money){
    //创建JDBCTemplate对象
    JdbcTemplate template = new JdbcTemplate(JDBCUtils.getDataSource());
    String sql1 = "update db1.account set balance = balance - ? where name = ?";
    String sql2 = "update db1.account set balance = balance + ? where name = ?";
    template.update(sql1, money,fromName);
    template.update(sql2, money,toName);
}

2. Pasos

 1. Importe el paquete jar ( paquete jar relacionado con JDBCTemplate-recursos de documentos Java-biblioteca CSDN )

marca de agua,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5rap5Y2z5pivTnVsbA==,size_14,color_FFFFFF,t_70,g_se,x_16

2. Crear objeto JdbcTemplate

Depende de la fuente de datosDataSource

JdbcTemplate template = new JdbcTemplate(JDBCUtils.getDataSource()); 

3. Llame al método JdbcTemplate para completar la operación CRUD.

  •  actualización(): ejecuta la instrucción DML. Agregar, eliminar y modificar declaraciones
        /**
         * 1. 修改1号数据的 salary 为 10000
         */
        @Test
        public void test1(){
            //2. 定义sql
            String sql = "update emp set salary = 10000 where id = 1001";
            //3. 执行sql
            int count = template.update(sql);
            System.out.println(count);
        }
        /**
         * 2. 添加一条记录
         */
        @Test
        public void test2(){
            String sql = "insert into emp(id,ename,dept_id) values(?,?,?)";
            int count = template.update(sql, 1015, "郭靖", 10);
            System.out.println(count);
        }
        /**
         * 3.删除刚才添加的记录
         */
        @Test
        public void test3(){
            String sql = "delete from emp where id = ?";
            int count = template.update(sql, 1015);
            System.out.println(count);
        }   
  • queryForMap(): el resultado de la consulta encapsula el conjunto de resultados en un conjunto de mapas, utiliza el nombre de la columna como clave y utiliza el valor como valor. Encapsula este registro en un conjunto de mapas. Nota: La longitud del conjunto de resultados consultado por este método solo puede ser 1.
         /**
         * 4.查询id为1001的记录,将其封装为Map集合
         * 注意:这个方法查询的结果集长度只能是1
         */
        @Test
        public void test4(){
            String sql = "select * from emp where id = ? or id = ?";
            Map<String, Object> map = template.queryForMap(sql, 1001,1002);
            System.out.println(map);      //{id=1001, ename=孙悟空, job_id=4, mgr=1004, joindate=2000-12-17, salary=10000.00, bonus=null, dept_id=20}
        }
  • queryForList (): el resultado de la consulta encapsula el conjunto de resultados en una colección de listas. Nota: encapsule cada registro en una colección de mapas y luego cargue la colección de mapas en la colección de listas.
        /**
         * 5. 查询所有记录,将其封装为List
         */
        @Test
        public void test5(){
            String sql = "select * from emp";
            List<Map<String, Object>> list = template.queryForList(sql);
            for (Map<String, Object> stringObjectMap : list) {
                System.out.println(stringObjectMap);
            }
        }
  • query(): consulta resultados, encapsula los resultados como objetos JavaBean parámetros de consulta: RowMapper Generalmente usamos la clase de implementación BeanPropertyRowMapper. Puede completar la encapsulación automática de datos en JavaBean new BeanPropertyRowMapper<type>(type.class)
         /**
         * 6. 查询所有记录,将其封装为Emp对象的List集合
         */
        @Test
        public void test6(){
            String sql = "select * from emp";
            List<Emp> list = template.query(sql, new RowMapper<Emp>() {
                @Override
                public Emp mapRow(ResultSet rs, int i) throws SQLException {
                    Emp emp = new Emp();
                    int id = rs.getInt("id");
                    String ename = rs.getString("ename");
                    int job_id = rs.getInt("job_id");
                    int mgr = rs.getInt("mgr");
                    Date joindate = rs.getDate("joindate");
                    double salary = rs.getDouble("salary");
                    double bonus = rs.getDouble("bonus");
                    int dept_id = rs.getInt("dept_id");
                    emp.setId(id);
                    emp.setEname(ename);
                    emp.setJob_id(job_id);
                    emp.setMgr(mgr);
                    emp.setJoindate(joindate);
                    emp.setSalary(salary);
                    emp.setBonus(bonus);
                    emp.setDept_id(dept_id);
                    return emp;
                }
            });
            for (Emp emp : list) {
                System.out.println(emp);
            }
        }
        /**
         * 6. 查询所有记录,将其封装为Emp对象的List集合
         */
        @Test
        public void test6_2(){
            String sql = "select * from emp";
            List<Emp> list = template.query(sql, new BeanPropertyRowMapper<Emp>(Emp.class));
            for (Emp emp : list) {
                System.out.println(emp);
            }
        }
  • queryForObject: consulta resultados, encapsula los resultados como objetos 
        /**
         * 7. 查询总记录数
         */
        @Test
        public void test7(){
            String sql = "select count(id) from emp";
            Long total = template.queryForObject(sql, Long.class);
            System.out.println(total);
        }

Supongo que te gusta

Origin blog.csdn.net/weixin_51418964/article/details/122971082
Recomendado
Clasificación