Mybatis学习(mybatis开发dao的方法)

SqlSession使用范围

  1. SqlSessionFactoryBuilder
    通过SqlSessionFactoryBuilder创建会话工厂SqlSessionFactory
    将SqlSessionFactoryBuilder当成一个工具类使用即可,不需要使用单例管理SqlSessionFactoryBuilder。
    在需要创建SqlSessionFactory时候,只需要new一次SqlSessionFactoryBuilder即可。
  2. SqlSessionFactory
    通过SqlSessionFactory创建SqlSession,使用单例模式管理sqlSessionFactory(工厂一旦创建,使用一个实例)。
    将来mybatis和spring整合后,使用单例模式管理sqlSessionFactory。
  3. SqlSession
    SqlSession是一个面向用户(程序员)的接口。
    SqlSession中提供了很多操作数据库的方法:如:selectOne(返回单个对象)、selectList(返回单个或多个对象)、。
    SqlSession是线程不安全的,在SqlSesion实现类中除了有接口中的方法(操作数据库的方法)还有数据域属性。
    SqlSession最佳应用场合在方法体内,定义成局部变量使用。

原始dao开发方法(程序员需要写dao接口和dao实现类)

  1. 思路
    程序员需要写dao接口和dao实现类。
    需要向dao实现类中注入SqlSessionFactory,在方法体内通过SqlSessionFactory创建SqlSession
  2. dao接口


    Mybatis学习(mybatis开发dao的方法)_第1张图片
    1.png
  3. 实现类
public class UserDaoImpl implements UserDao {
    //需要向dao实现类中注入SqlSessionFactory
    // 这里通过构造方法注入
    private SqlSessionFactory sqlSessionFactory;
    public UserDaoImpl(SqlSessionFactory sqlSessionFactory) {
        this.sqlSessionFactory = sqlSessionFactory;
    }

    @Override
    public User findUserById(int id) throws Exception {
        SqlSession sqlSession = sqlSessionFactory.openSession();

        User user = sqlSession.selectOne("test.findUserById", id);

        // 释放资源
        sqlSession.close();

        return user;

    }

    @Override
    public void insertUser(User user) throws Exception {
        SqlSession sqlSession = sqlSessionFactory.openSession();

        //执行插入操作
        sqlSession.insert("test.insertUser", user);

        // 提交事务
        sqlSession.commit();

        // 释放资源
        sqlSession.close();

    }

    @Override
    public void deleteUser(int id) throws Exception {
        SqlSession sqlSession = sqlSessionFactory.openSession();

        //执行插入操作
        sqlSession.delete("test.deleteUser", id);

        // 提交事务
        sqlSession.commit();

        // 释放资源
        sqlSession.close();
    }
}
  1. 测试代码


    Mybatis学习(mybatis开发dao的方法)_第2张图片
    2.png

mapper代理方法(程序员只需要mapper接口(相当 于dao接口))

  1. 思路(mapper代理开发规范)
    程序员还需要编写mapper.xml映射文件
    程序员编写mapper接口需要遵循一些开发规范,mybatis可以自动生成mapper接口实现类代理对象。
    开发规范:
    (1)在mapper.xml中namespace等于mapper接口地址


    3.png

    (2)mapper.java接口中的方法名和mapper.xml中statement的id一致
    (3)mapper.java接口中的方法输入参数类型和mapper.xml中statement的parameterType指定的类型一致。
    (4)mapper.java接口中的方法返回值类型和mapper.xml中statement的resultType指定的类型一致。


    4.png

    5.png
  2. mapper.java


    6.png
  3. mapper.xml


    7.png
  4. 在SqlMapConfig.xml中加载mapper.xml


    Mybatis学习(mybatis开发dao的方法)_第3张图片
    8.png
  5. 测试


    Mybatis学习(mybatis开发dao的方法)_第4张图片
    9.png
  6. 一些问题总结
    (1)代理对象内部调用selectOne或selectList
    如果mapper方法返回单个pojo对象(非集合对象),代理对象内部通过selectOne查询数据库。
    如果mapper方法返回集合对象,代理对象内部通过selectList查询数据库。
    (2)mapper接口方法参数只能有一个是否影响系统开发
    mapper接口方法参数只能有一个,系统是否不利于扩展维护。
    系统 框架中,dao层的代码是被业务层公用的。
    即使mapper接口只有一个参数,可以使用包装类型的pojo满足不同的业务方法的需求。
    注意:持久层方法的参数可以包装类型、map。。。,service方法中建议不要使用包装类型(不利于业务层的可扩展)。

你可能感兴趣的:(Mybatis学习(mybatis开发dao的方法))