Spring----JDBCTemplate

JDBCTemplate

JDBCTemplate就是Spring对JDBC的在封装,方便对数据库进行操作。

在xml文件中

首先引入命名空间context,使用context:property-override标签引入外部properties文件,location指明位置

注入DruidDataSource的对象并完成属性注入,value内的内容可以直接注入,也能通过${ }【Spring表达式】进行获取配置文件中的内容

创建JDBCTemplate对象,将DruidDataSource对象注入进去

最后开启组件扫描


​
    
​
    
​
    
        
        
        
        
    

    
        
    

在DaoImpl类中

生成对象,注入JDBCTemplate的bean对象

@Repository
public class UserDaoImpl {
    @Autowired
    private JdbcTemplate jdbcTemplate;
}

在Service中

生成对象,注入DaoImpl对象

@Service
public class UserService {
    @Autowired
    private UserDao userDao;
}

使用JDBCTemplate操作数据库增加操作

首先创建一个Dao接口和实现类,添加注解创建对象,然后创建一个数据库表和实体类【代表数据库表的实体类中的属性要和数据库表中的列名一样,后面的查询操作会拿不到数据。因为是反射机制】

创建service层代码,并注入Dao接口的bean对象,调用接口方法

配置文件中【有错】


​
    
    
    
    
    
        
        
        
        
    
​

    
        
    

Dao中

@Component
public interface UserDao {
    void add(User user);
}

DaoImpl中

@Repository
public class UserDaoImpl implements UserDao {
    @Autowired
    private JdbcTemplate jdbcTemplate;
​
    @Override
    public void add(User user) {
        String sql = "insert into o_User values (?,?,?)";
        int update = jdbcTemplate.update(sql, null, user.getUsername(), user.getPassword());
        System.out.println(update);
    }
}

Service中【没建立接口】

@Service
public class UserService {
    @Autowired
    private UserDao userDao;
​
    public void addUser(User user){
        userDao.add(user);
    }
}

随便建一个测试类

  
  ApplicationContext context = new ClassPathXmlApplicationContext("hao.xml");
@Test
public void testJDBCTemplate(){
    UserService userService = context.getBean("userService", UserService.class);
    User user = new User();
    user.setUsername("老王");
    user.setPassword("123abc");
    System.out.println(user.getPassword());
    userService.addUser(user);
}

问题出现了,本来输出一个影响行数但是报错了

Could not process key 'url' in PropertyOverrideConfigurer; nested exception is org.springframework.beans.factory.BeanInitializationException: Invalid key 'url': expected 'beanName.property'

这种的还有另一种说是jdbcTemplate建立的bean找不到,或者创建DaoImpl的bean出错,还有就是说表达式指向的内容找不到。其实这都是借口,问题是这个【DruidDataSource】类的bean对象的id他在上面叫jdbc,现在我改成了druid,然后在JDBCTemplate中注入这个bean就行,他就行了。神奇吧,神奇死了。

他半天一直在叫找不到jdbc这个bean在哪里,过一会又叫找不到druid这个bean在哪里。


    
    
    
    



    

这时jdbc.properties文件【名字就叫这个】,mysql是8.0.21版本,可以自己去找对应的8.0.21的驱动jar包

druid.driverClassName=com.mysql.cj.jdbc.Driver
druid.url=jdbc:mysql://localhost:3308/o_user?characterEncoding=utf8&useSSL=true&serverTimezone=UTC
druid.username=root
druid.password=123456

JDBCTemplate对数据库表进行删除和修改

一样使用update方法,只是sql语句不一样。使用前先把语句拿到navicat里面试试行不行的通

剩下的就是调用了

@Override
public void update(User user) {
    String sql = "update o_USer set username=?,userpassword=? where id=?";
    int update = jdbcTemplate.update(sql, user.getUsername(), user.getPassword(), user.getUserid());
    System.out.println(update);
}
​
@Override
public void delete(User user) {
    String sql = "delete from o_User where id=?";
    int update = jdbcTemplate.update(sql, user.getUserid());
    System.out.println(update);
}

JDBCTemplate对数据库进行查询操作

返回数值

使用JDBCTemplate进行查询操作时,要用到方法queryForObject。将sql语句的查询结果返回为Integer类型。

@Override
public int selectCount() {
    String sql = "select count(*) from O_user";
    Integer count = jdbcTemplate.queryForObject(sql, Integer.class);
    return count;
}

返回对象

当希望返回类型是一个对象时,同样使用queryForObject方法,但是使用另一种参数结构,在方法中创建一个BeanPropertyRoMapper<>()对象,这个类实现了RowMapper接口,该接口可以真对不同返回类型的值,对数据做进一步的封装,里面的参数第一个是sql语句,第二个是这个BeanPropertyRowMapper对象,在它后面的泛型参数里加上返回的类对象,并在括号里注入泛型类对象的class,最后就是查询语句占位符对应的变量。

@Override
public User selectUserWithId(Integer id) {
    String sql = "select * from O_user where id=?";
    User user = jdbcTemplate.queryForObject(sql, new BeanPropertyRowMapper(User.class), id);
    return user;
}

返回集合

在处理返回的方法上使用的query方法,它的参数和上面的那个BeanPropertyRowMapper接口实现类一样。在使用上注意就行了

@Override
public List queryAllUser() {
    String sql = "select * from O_user";
    List userList = jdbcTemplate.query(sql, new BeanPropertyRowMapper(User.class));
    return userList;
}

JDBCTemplate对数据库进行批量操作

批量插入操作

在进行批量插入操作时使用方法batchUpdate,他第一个参数是sql语句,第二个参数是要插入的list数组集合。

@Override
public void batchAddUser(List list) {
    String sql = "insert into O_user values (?,?,?)";
    int[] lines = jdbcTemplate.batchUpdate(sql, list);
    System.out.println(Arrays.toString(lines));
}

插入时【纯是数组和对象插入的操作】

List object = new ArrayList<>();
 Object[] u1 = {null,"动物","猩猩"};
 Object[] u2 = {null,"植物","花"};
 Object[] u3 = {null,"鱼","石斑"};
 object.add(u1);
 object.add(u2);
 object.add(u3);
 userService.batchAdd(object);
 List userList = userService.queryAllUser();

批量修改操作

在进行批量修改操作时,注意参数和占位符对应位置,不要设置错属性

@Override
public void batchUpdateByIdUser(List list) {
    String sql = "update o_USer set username=?,userpassword=? where id=?";
    int[] lines = jdbcTemplate.batchUpdate(sql, list);
    System.out.println(Arrays.toString(lines));
}

使用

List object = new ArrayList<>();
 Object[] u1 = {"动物","人",12};
 Object[] u2 = {"植物","树",13};
 Object[] u3 = {"鱼","泡泡",14};
 object.add(u1);
 object.add(u2);
 object.add(u3);
 userService.batchDeleteById(object);

批量删除操作

@Override
public void batchDeleteByIdUser(List list) {
    String sql = "delete from o_User where id=?";
    int[] ints = jdbcTemplate.batchUpdate(sql, list);
    System.out.println(Arrays.toString(ints));
}

使用

数组就是好,一两个、十个一百个。都能存进去

List object = new ArrayList<>();
 Object[] u1 = {12};
 Object[] u2 = {13};
 Object[] u3 = {14};
 object.add(u1);
 object.add(u2);
 object.add(u3);
 userService.batchDeleteById(object);

你可能感兴趣的:(Spring,spring)