JdbcTemplate详解

176 阅读1分钟

一、JDBCTemplate简介

1、什么是JDBCTemplate
(1)Spring框架对JDBC进行封装,使用JDBCTemplate可以更加方便的对数据库进行操作。
2、准备工作
(1)引入相关jar包
下载如下依赖: image.png (2)在Spring配置文件中配置数据库连接池

<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" destroy-method="close">
    <property name="url" value= "jdbc:mysql///book"/>
    <property name="username" value="root"/>
    <property name="password" value="123456"/>
    <property name="driverClassName" value="com.mysql.jdbc.Driver"/>
</bean>

(3)配置JdbcTemplate对象,注入datasource

<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
    <property name="dataSource" ref="dataSource"></property>
</bean>

(4)创建service类,创建dao类,在dao里注入jdbcTemplate对象

@Service
public class BookService {
    @Autowired
    private BookDao bookDao;
}
@Repository
public class BookDaoImpl {
    @Autowired
    private JdbcTemplate jdbcTemplate;
}

二、JdbcTemplate操作数据库(添加)

1、对应数据库表创建实体类
2、编写service和dao类
(1)使用dao进行数据库操作 (2)调用JdbcTemplate对象里的update方法实现添加操作

@Repository
public class BookDaoImpl implements BookDao{
    @Autowired
    private JdbcTemplate jdbcTemplate;


    @Override
    public int add(Book book) {
        String sql = "insert into Book(Bname,Bprice) values(?,?)";
        Object[] params = {book.getBname(),book.getBprice()};
        int update = jdbcTemplate.update(sql,params);
        return update;
    }
}

(3)测试方法

public void testJdbcTemplate(){
    ApplicationContext context = new ClassPathXmlApplicationContext("bean1.xml");
    BookService service = context.getBean("bookService",BookService.class);
    Book book = context.getBean("book", Book.class);
    service.add(book);
}

三、JdbcTemplate操作数据库(修改和删除)

修改和删除的操作方法与增加的操作方法非常类似

四、JdbcTemplate操作数据库(查询操作)

1、查询返回某个值

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

2、查询返回对象

@Override
public Book queryone(String id) {
    String sql = "select * from Book where id=?";
    Book book = jdbcTemplate.queryForObject(sql, new BeanPropertyRowMapper<Book>(Book.class), id);
    return book;
}

3、查询返回集合

@Override
public List<Book> queryAll() {
    String sql = "select * from Book";
    List<Book> bookList = jdbcTemplate.query(sql, new BeanPropertyRowMapper<Book>(Book.class));
    return bookList;
}

五、JdbcTemplate操作数据库(批量操作)

1、批量操作:操作表里面多条记录
2、JdbcTemplate实现批量添加操作

@Override
public void batchAdd(List<Object[]> batchargs) {
    String sql = "insert into Book(Bname,Bprice) values(?,?)";
    int[] ints = jdbcTemplate.batchUpdate(sql, batchargs);
    System.out.println(Arrays.toString(ints));
}

测试代码

public void testJdbcTemplate(){
    ApplicationContext context = new ClassPathXmlApplicationContext("bean1.xml");
    BookService service = context.getBean("bookService",BookService.class);
    //Book book = context.getBean("book", Book.class);
    //service.add(book);
    //System.out.println(service.queryCount());

    Object[] o1 = {"C++",10};
    Object[] o2 = {"Spring",20};
    Object[] o3 = {"SpringCloud",30};
    List<Object[]> list = new ArrayList<Object[]>();
    list.add(o1);
    list.add(o2);
    list.add(o3);
    service.batchAdd(list);
}