Spring篇-JdbcTemplate

JdbcTemplate

Spring 框架对 JDBC 进行封装,使用 JdbcTemplate 方便实现对数据库操作

使用前的准备

  • 引入相关 jar 包

Spring篇-JdbcTemplate_第1张图片

  • 在 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 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 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 batchArgs) {
 String sql = "delete from t_book where user_id=?";
 int[] ints = jdbcTemplate.batchUpdate(sql, batchArgs);
 System.out.println(Arrays.toString(ints));
}
//批量删除
List 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 bookList = userService.findBookList();
        System.out.println(bookList);
    }


}

你可能感兴趣的:(#,Spring,SSM,spring,java)