package com.template;
import com.dataSource.druid.utils.DBUtils;
import com.domain.User;
import com.sun.tracing.dtrace.ArgsAttributes;
import org.junit.Test;
import org.springframework.jdbc.core.BeanPropertyRowMapper;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.RowMapper;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.List;
import java.util.Map;
/**
* JbbcTemplate 的update
*/
public class JdbcTemplateDemo02 {
JdbcTemplate jdbcTemplate = new JdbcTemplate(DBUtils.getDataSource());
@Test
public void add () {
int count = jdbcTemplate.update("INSERT INTO account VALUES (?,?,?)",null,"sa",10);
System.out.println(count);
}
@Test
public void delete () {
int count = jdbcTemplate.update("delete FROM account WHERE id = ?",5);
System.out.println(count);
}
@Test
public void update () {
int count = jdbcTemplate.update("UPDATE account SET money = ? WHERE id = ?",0,4);
System.out.println(count);
}
@Test
public void test () {
//注意我们的map只能封装结果集是一条的数据
Map<String,Object> map = jdbcTemplate.queryForMap("select * from account where id = ?",1);
System.out.println(map);
}
@Test
public void test01 () {
//注意当我们封装多条记录的时候我们可以使用 封装list的方法 这个方法就是每一个记录封装成一个map放到list中
List<Map<String,Object>> list = jdbcTemplate.queryForList("select * from account");
System.out.println(list);
}
@Test
public void test02 () {
//查询出多条记录 把它封装成对应的对象 方法list里面
List<User> list = jdbcTemplate.query("select * from account", new RowMapper<User>() {
@Override
public User mapRow(ResultSet resultSet, int i) throws SQLException {
User user = new User();
user.setId(resultSet.getInt("id"));
user.setMoney(resultSet.getInt("money"));
user.setUsername(resultSet.getString("username"));
return user;
}
});
System.out.println(list);
}
/**
* 这个方法是真的好用啊
*/
@Test
public void test03 () {
//查询出多条记录 把它封装成对应的对象 方法list里面 我们使用它们提供的实现类
List<User> list = jdbcTemplate.query("select * from account",new BeanPropertyRowMapper<User>(User.class));
System.out.println(list);
}
@Test
public void test04 () {
//就是把我们查询出来的结果封装成你想要的那个样子 后面那个参数传你想要的那个参数的字节码
Long aLong = jdbcTemplate.queryForObject("select COUNT(id) from account",Long.class);
System.out.println(aLong);
}
}