JdbcTemplate
Spring 框架对 JDBC 进行封装,使用 JdbcTemplate 方便实现对数据库操作
使用前的准备
- 引入相关 jar 包
- 在 spring 配置文件配置数据库连接池
<!-- 数据库连接池 -->
<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource"
destroy-method="close">
<property name="url" value="jdbc:mysql://localhost:3306/test" />
<property name="username" value="root" />
<property name="password" value="cVzhanshi" />
<property name="driverClassName" value="com.mysql.jdbc.Driver" />
</bean>
- 配置 JdbcTemplate 对象,注入 DataSource
<!-- JdbcTemplate 对象 -->
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
<!--注入 dataSource-->
<property name="dataSource" ref="dataSource"></property>
</bean>
- 创建 service 类,创建 dao 类,在 dao 注入 jdbcTemplate 对象 ,在service注入dao
/*DAO*/
@Repository
public class UserDaoImpl implements UserDao{
@Autowired
private JdbcTemplate jdbcTemplate;
...
}
/*service*/
@Service
public class UserService {
@Autowired
private UserDao userDao;
...
}
JdbcTemplate 操作数据库(添加)
- 创建实体类User
public class User {
private String userId;
private String userName;
private String passWord;
private String addRess;
private String phone;
...
}
- 编写 service 和 dao
调用 JdbcTemplate 对象里面 update 方法实现添加操作
有两个参数
- 第一个参数:sql 语句
- 第二个参数:可变参数,设置 sql 语句值
代码实现:
/*service*/
public int insertUser(User user){
int i = userDao.addUser(user);
return i;
}
/*dao*/
//插入
@Override
public int addUser(User user) {
String sql = "insert into user values(?,?,?,?,?)";
int update = jdbcTemplate.update(sql, user.getUserId(), user.getUserName(), user.getPassWord(), user.getAddRess(), user.getPhone());
return update;
}
JdbcTemplate 操作数据库(修改和删除)
修改、删除与插入类似,用的方法相同
修改
/*service*/
public int updateUser(User user){
int i = userDao.updateUser(user);
return i;
}
//修改
@Override
public int updateUser(User user) {
String sql = "update user set name=?,address=? where id=?";
int update = jdbcTemplate.update(sql, user.getUserName(), user.getAddRess(), user.getUserId());
return update;
}
删除
/*service*/
public int deleteUser(String id){
int i = userDao.deleteUser(id);
return i;
}
//删除
@Override
public int deleteUser(String id) {
String sql = "delete from user where id=?";
int update = jdbcTemplate.update(sql, id);
return update;
}
JdbcTemplate 操作数据库(查询返回某个值)
类似于“ 查询表里面有多少条记录,返回是某个值 ”这样的要求
使用 JdbcTemplate 实现查询返回某个值代码
有两个参数
- 第一个参数:sql 语句
- 第二个参数:返回类型 Class
//sevice
public int selcetCount(){
int count = userDao.selectCount();
return count;
}
//dao
@Override
public int selectCount() {
String sql = "select count(*) from user";
Integer count = jdbcTemplate.queryForObject(sql, Integer.class);
return count;
}
JdbcTemplate 操作数据库(查询返回对象)
场景:查询用户详情
JdbcTemplate 实现查询返回对象
有三个参数
- 第一个参数:sql 语句
- 第二个参数:RowMapper 是接口,针对返回不同类型数据,使用这个接口里面实现类完成 数据封装
- 第三个参数:sql 语句值
//service
public int selcetCount(){
int count = userDao.selectCount();
return count;
}
//dao
//查询一个用户
@Override
public User findBookInfo(String id) {
String sql = "select id userId,name userName,password,address,phone from user where id=?";
User user = jdbcTemplate.queryForObject(sql, new BeanPropertyRowMapper<User>(User.class), id);
return user;
}
JdbcTemplate 操作数据库(查询返回集合)
场景:查询图书列表分页
调用 JdbcTemplate 方法实现查询返回集合
有三个参数
- 第一个参数:sql 语句
- 第二个参数:RowMapper 是接口,针对返回不同类型数据,使用这个接口里面实现类完成 数据封装
- 第三个参数:sql 语句值
//service
public List<User> findBookList(){
List<User> list = userDao.getBeanList();
return list;
}
//dao
@Override
public List<User> getBeanList() {
String sql = "select id userId,name userName,password,address,phone from user";
List<User> query = jdbcTemplate.query(sql, new BeanPropertyRowMapper<User>(User.class));
return query;
}
JdbcTemplate 操作数据库(批量操作)
批量操作:操作表里面多条记录
批量添加
JdbcTemplate 实现批量添加操作
原理:
将list中的每组数据执行sql语句,实现了批量操作
有两个参数
- 第一个参数:sql 语句
- 第二个参数:List 集合,添加多条记录数据
//批量添加
@Override
public void batchAddBook(List<Object[]> batchArgs) {
String sql = "insert into t_book values(?,?,?)";
int[] ints = jdbcTemplate.batchUpdate(sql, batchArgs);
System.out.println(Arrays.toString(ints));
}
//批量添加测试
List<Object[]> batchArgs = new ArrayList<>();
Object[] o1 = {
"3","java","a"};
Object[] o2 = {
"4","c++","b"};
Object[] o3 = {
"5","MySQL","c"};
batchArgs.add(o1);
batchArgs.add(o2);
batchArgs.add(o3);
//调用批量添加
bookService.batchAdd(batchArgs);
批量修改
//批量修改
@Override
public void batchUpdateBook(List<Object[]> batchArgs) {
String sql = "update t_book set username=?,ustatus=? where user_id=?";
int[] ints = jdbcTemplate.batchUpdate(sql, batchArgs);
System.out.println(Arrays.toString(ints));
}
//批量修改
List<Object[]> batchArgs = new ArrayList<>();
Object[] o1 = {"java0909","a3","3"};
Object[] o2 = {"c++1010","b4","4"};
Object[] o3 = {"MySQL1111","c5","5"};
batchArgs.add(o1);
batchArgs.add(o2);
batchArgs.add(o3);
//调用方法实现批量修改
bookService.batchUpdate(batchArgs);
批量删除
//批量删除
@Override
public void batchDeleteBook(List<Object[]> batchArgs) {
String sql = "delete from t_book where user_id=?";
int[] ints = jdbcTemplate.batchUpdate(sql, batchArgs);
System.out.println(Arrays.toString(ints));
}
//批量删除
List<Object[]> batchArgs = new ArrayList<>();Object[] o1 = {"3"};
Object[] o2 = {"4"};
batchArgs.add(o1);
batchArgs.add(o2);
//调用方法实现批量删除
bookService.batchDelete(batchArgs);
附录:完整代码
UserDaoImpl.java
/**
* @author cVzhanshi
* @create 2021-04-16 21:27
*/
@Repository
public class UserDaoImpl implements UserDao{
@Autowired
private JdbcTemplate jdbcTemplate;
//插入
@Override
public int addUser(User user) {
String sql = "insert into user values(?,?,?,?,?)";
int update = jdbcTemplate.update(sql, user.getUserId(), user.getUserName(), user.getPassWord(), user.getAddRess(), user.getPhone());
return update;
}
//修改
@Override
public int updateUser(User user) {
String sql = "update user set name=?,address=? where id=?";
int update = jdbcTemplate.update(sql, user.getUserName(), user.getAddRess(), user.getUserId());
return update;
}
//删除
@Override
public int deleteUser(String id) {
String sql = "delete from user where id=?";
int update = jdbcTemplate.update(sql, id);
return update;
}
//查询一个用户
@Override
public User findBookInfo(String id) {
String sql = "select id userId,name userName,password,address,phone from user where id=?";
User user = jdbcTemplate.queryForObject(sql, new BeanPropertyRowMapper<User>(User.class), id);
return user;
}
//获取记录数
@Override
public int selectCount() {
String sql = "select count(*) from user";
Integer count = jdbcTemplate.queryForObject(sql, Integer.class);
return count;
}
//获取用户列表
@Override
public List<User> getBeanList() {
String sql = "select id userId,name userName,password,address,phone from user";
List<User> query = jdbcTemplate.query(sql, new BeanPropertyRowMapper<User>(User.class));
return query;
}
}
UserService.java
/**
* @author cVzhanshi
* @create 2021-04-16 21:27
*/
@Service
public class UserService {
@Autowired
private UserDao userDao;
public int insertUser(User user){
int i = userDao.addUser(user);
return i;
}
public int updateUser(User user){
int i = userDao.updateUser(user);
return i;
}
public int deleteUser(String id){
int i = userDao.deleteUser(id);
return i;
}
public int selcetCount(){
int count = userDao.selectCount();
return count;
}
public User findBookInfo(String id){
User user = userDao.findBookInfo(id);
return user;
}
public List<User> findBookList(){
List<User> list = userDao.getBeanList();
return list;
}
}
UserDao.java
/**
* @author cVzhanshi
* @create 2021-04-16 21:27
*/
public interface UserDao {
int addUser(User user);
int updateUser(User user);
int deleteUser(String id);
int selectCount();
User findBookInfo(String id);
List<User> getBeanList();
}
Test.java
/**
* @author cVzhanshi
* @create 2021-04-16 21:32
*/
public class JDBCTest {
private UserService userService;
//读取配置文件 获取service对象
@Before
public void before(){
ApplicationContext context = new ClassPathXmlApplicationContext("bean.xml");
userService = context.getBean("userService", UserService.class);
}
@Test
public void insert(){
int i = userService.insertUser(new User("6", "cVzhanshi", "root", "jiangxi", "10086"));
System.out.println(i);
}
@Test
public void update(){
int i = userService.updateUser(new User("6", "cV展示", null, "beijin", null));
System.out.println(i);
}
@Test
public void delete(){
int i = userService.deleteUser("5");
System.out.println(i);
}
@Test
public void count(){
int i = userService.selcetCount();
System.out.println(i);
}
@Test
public void getBean(){
User bookInfo = userService.findBookInfo("6");
System.out.println(bookInfo);
}
@Test
public void getBeanList(){
List<User> bookList = userService.findBookList();
System.out.println(bookList);
}
}
转载:https://blog.csdn.net/qq_45408390/article/details/115774237
查看评论