Spring JDBC Spring框架对JDBC的简单封装。提供了一个JDBCTemplate对象简化JDBC的开发
1. 导入jar包 4 + 1
2. 创建JdbcTemplate对象。依赖于数据源DataSource
JdbcTemplate template = new JdbcTemplate(ds);
3. 调用JdbcTemplate的方法来完成CRUD的操作
update():执行DML语句。增、删、改语句
queryForMap():查询结果将结果集封装为map集合,将列名作为key,将值作为value 将这条记录封装为一个map集合
注意:这个方法查询的结果集长度只能是1
queryForList():查询结果将结果集封装为list集合
注意:将每一条记录封装为一个Map集合,再将Map集合装载到List集合中
query():查询结果,将结果封装为JavaBean对象
query的参数:RowMapper
一般我们使用BeanPropertyRowMapper实现类。可以完成数据到JavaBean的自动封装
new BeanPropertyRowMapper<类型>(类型.class)
queryForObject:查询结果,将结果封装为对象
一般用于聚合函数的查询
/**
* JdbcTemplate入门
*/
public class JdbcTemplateDemo1 {
public static void main(String[] args) {
//1.导入jar包
//2.创建JDBCTemplate对象
JdbcTemplate template = new JdbcTemplate(JDBCUtils.getDataSource());
//3.调用方法
String sql = "update account set balance = 5000 where id = ?";
int count = template.update(sql, 3);//insert update delete
System.out.println(count);
//自已关闭,自已归还
}
}
数据库准备
CREATE TABLE `emp` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`username` varchar(25) DEFAULT NULL,
`job` varchar(100) DEFAULT NULL,
`addr` varchar(25) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
INSERT INTO `test`.`emp`(`id`, `username`, `job`, `addr`) VALUES (1, 'tom', '开发', '上海');
INSERT INTO `test`.`emp`(`id`, `username`, `job`, `addr`) VALUES (2, 'mary', '测试', '郑州');
实体类
// 注意事项:java属性名 要与 数据库的字段名保持一致,不然无法封装
public class Emp {
private Integer id;
private String username;
private String job;
private String addr;
//提供有参无对构造方法
//提供get set 方法
//提供toString方法
}
测试类
public class Test1 {
//获取数据源
private DataSource dataSource = JDBCUtil.getDataSource();
//使用jdbcTemplate 技术,简化jdbc操作
private JdbcTemplate JdbcTemplate = new JdbcTemplate(dataSource);
//修改
@Test
public void testUpdateById(){
String sql ="update emp set job = '财务' where id = ? ";
int i = this.JdbcTemplate.update(sql, 2);
System.out.println(i);
}
//添加
@Test
public void testAdd(){
String sql ="insert into emp (id , username , job ,addr) values(?,?,?,?)";
int i = JdbcTemplate.update(sql, null, "yiyan", "小秘", "郑州");
System.out.println(i);
}
//删除
@Test
public void testDeleteById(){
String sql ="delete from emp where id = ?";
int i = JdbcTemplate.update(sql, 1);
System.out.println(i);
}
//查询数据返回list
@Test
public void testQueryById(){
String sql ="select * from emp where id = ?";
//返回的是list
List<Emp> emps = this.JdbcTemplate.query(sql, new BeanPropertyRowMapper<>(Emp.class), 2);
for(Emp e : emps){
System.out.println(e);
}
}
//查询条数
@Test
public void testForObject(){
String sql = "select count(1) from emp";
Long i = this.JdbcTemplate.queryForObject(sql, Long.class);
System.out.println(i);
}
//查询数据返回map
@Test
public void testQuery2(){
String sql = "select * from emp where id = ?";
//返回map
Map<String, Object> map = this.JdbcTemplate.queryForMap(sql,2);
//map遍历
Set<String> set = map.keySet();
for(String key : set){
Object o = map.get(key);
System.out.println(key+" : "+o);
}
}
/**
* 查询数据返回对象中
* 注意事项: 返回的单个对象必须要有结果,这个结果只能接受一条
*
*/
public Emp queryTest3(){
Emp emp = null;
try {
String sql = "select * from emp where id = ?";
//如果这里查到数据,就直接返回
return this.template.queryForObject(sql, new BeanPropertyRowMapper<>(Emp.class),9);
} catch (DataAccessException e) {
//没有查询到,方式一
// throw new RuntimeException("没有查询到数据!");
//没有查询到,方式二
return null;
}
}
//测试 查询数据返回对象中
public static void main(String[] args) {
JdbcTemplateDemo jt = new JdbcTemplateDemo();
Emp emp = jt.queryTest3();
System.out.println(emp);
}
}