一、JDBCTemplate简介
1、什么是JDBCTemplate
(1)Spring框架对JDBC进行封装,使用JDBCTemplate可以更加方便的对数据库进行操作。
2、准备工作
(1)引入相关jar包
下载如下依赖:
(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);
}