一、JdbcTemplate(概念和准备):
1、什么是 JdbcTemplate:
(1)Spring 框架对 JDBC 进行封装,使用 JdbcTemplate 方便实现对数据库操作
spring可以单独进行使用,也可以整合其他框架进行使用;
2、准备工作
(1)引入相关 jar 包
(2)在 spring 配置文件配置数据库连接池
<!-- 数据库连接池 -->
<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource"
destroy-method="close">
<property name="url" value="jdbc:mysql:///user_db" />
<property name="username" value="root" />
<property name="password" value="root" />
<property name="driverClassName" value="com.mysql.jdbc.Driver" />
</bean>
(3)配置 JdbcTemplate 对象,注入 DataSource
<!-- JdbcTemplate对象-->
<bean id="JdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
<!--注入-->
<property name="dataSource" ref="dataSource"></property>
这里的dateSourse是上面的连接池id
</bean>
▶ 接下来是源码解析
JdbcTemplate.class里面:
无参构造
public JdbcTemplate() {
}
有参构造
public JdbcTemplate(DataSource dataSource) {
this.setDataSource(dataSource);
this.afterPropertiesSet();
}
JdbcAccessor.class里面:
ctrl+左键,点击setDataSource()
public void setDataSource(@Nullable DataSource dataSource) {
this.dataSource = dataSource;
}
二、JdbcTemplate 操作数据库(添加):
1、对应数据库创建实体类:
public class Book {
private String userId;
private String username;
private String ustatus;
public String getUserId() {
return userId;
}
public void setUserId(String userId) {
this.userId = userId;
}
}
2、编写 service 和 dao
(1)在 dao 进行数据库添加操作
(2)调用 JdbcTemplate 对象里面 update 方法实现添加操作
jdbcTemplate.update(sql,args);
⚫ 有两个参数
⚫ 第一个参数:sql 语句
⚫ 第二个参数:可变参数,设置 sql 语句值
@Repository
public class BookDaoImpl implements BookDao{
//注入 JdbcTemplate
@Autowired
private JdbcTemplate jdbcTemplate;
@Override
public void add(Book book) {
String sql = "insert into t_book values(?,?,?)";
Object[] args = {book.getUserId(), book.getUsername(), book.getUstatus()}; //可变数组
int update = jdbcTemplate.update(sql,args);
System.out.println(update);
}
}
3、测试类
public class TestBook {
@Test
public void testJdbcTemplate(){
ApplicationContext context =
new ClassPathXmlApplicationContext("bean1.xml");
BookService bookService = context.getBean("bookService", BookService.class);
Book book = new Book();
book.setUserId("1");
book.setUsername("java");
book.setUstatus("a");
bookService.addBook(book);
}
}
这里总结一下顺序:
1、扫描bean1.xml配置文件
2、开启组件扫描 有注解的就创建类
3、(创建BookService类,注入增强的方法addBook(book{“1”,“java”,“a”})
JdbcTemplate 操作数据库(查询返回对象):
1、场景:查询图书详情
2、JdbcTemplate 实现查询返回对象
⚫ 有三个参数
⚫ 第一个参数:sql 语句
⚫ 第二个参数:RowMapper 是接口,针对返回不同类型数据,使用这个接口里面实现类完成
数据封装
⚫ 第三个参数:sql 语句值