三、MyBatis通过DAO层实现CRUD操作

本文详细介绍了MyBatis通过DAO层实现CRUD操作的两种方式,包括传统开发方式和Mapper接口代理开发方式。重点讲解了Mapper接口代理方式下的findById、保存、更新、删除、模糊查询和聚合函数等操作的实现步骤,以及与JDBC编程的比较。
摘要由CSDN通过智能技术生成

1 传统开发方式(了解)

使用MyBatis开发Dao,通常有两个方法,即传统Dao开发方式和Mapper接口代理开发方式。而现在主流的开发方式是接口代理开发方式,这种方式总体上更加简便。我们的课程讲解也主要以接口代理开发方式为主。在第二章节已经给大家介绍了基于代理方式的dao开发,现在给大家介绍一下基于传统编写Dao实现类的开发方式。

1.1 持久层Dao接口

/**
 * <p>Title: IUserDao</p>
 * <p>Description: 用户的业务层接口</p>
 */
public interface IUserDao {
   
    /**
     * 查询所有用户
     * @return
     */
    List<User> findAll();

    /**
     * 根据id查询
     * @param userId
     * @return
     */
    User findById(Integer userId);

    /**
     * 保存用户
     * @param user
     * @return 影响数据库记录的行数
     */
    int saveUser(User user);

    /**
     * 更新用户
     * @param user
     * @return 影响数据库记录的行数
     */
    int updateUser(User user);

    /**
     * 根据id删除用户
     * @param userId
     * @return
     */
    int deleteUser(Integer userId);

    /**
     * 查询总记录条数
     * @return
     */
    int findTotal();

	/**
     * 根据姓名模糊查询
     * @return
     */
    List<User> findLikeName(String username);
}

1.2 持久层Dao实现类

/**
 * <p>Title: UserDaoImpl</p>
 * <p>Description: dao的实现类</p>
 */
public class UserDaoImpl implements IUserDao {
   
    private SqlSessionFactory factory;

    public UserDaoImpl(SqlSessionFactory factory) {
   
        this.factory = factory;
    }

    @Override
    public List<User> findAll() {
   
        SqlSession session = factory.openSession();
        List<User> users = session.selectList("com.itheima.dao.IUserDao.findAll");
        session.close();
        return users;
    }

    @Override
    public User findById(Integer userId) {
   
        SqlSession session = factory.openSession();
        User user = session.selectOne("com.itheima.dao.IUserDao.findById", userId);
        session.close();
        return user;
    }

    @Override
    public int saveUser(User user) {
   
        SqlSession session = factory.openSession();
        int res = session.insert("com.itheima.dao.IUserDao.saveUser", user);
        session.commit();
        session.close();
        return res;
    }

    @Override
    public int updateUser(User user) {
   
        SqlSession session = factory.openSession();
        int res = session.update("com.itheima.dao.IUserDao.updateUser", user);
        session.commit();
        session.close();
        return res;
    }

    @Override
    public int deleteUser(Integer userId) {
   
        SqlSession session = factory.openSession();
        int res = session.delete("com.itheima.dao.IUserDao.deleteUser", userId);
        session.commit();
        session.close();
        return res;
    }

    @Override
    public int findTotal() {
   
        SqlSession session = factory.openSession();
        int res = session.selectOne("com.itheima.dao.IUserDao.findTotal");
        session.close();
        return res;
    }

	@Override
    public List<User> findLikeName(String username) {
   
        SqlSession session = factory.openSession<
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值