zoukankan      html  css  js  c++  java
  • Mybatis环境搭建中的案例分析 及 如果自己编写DAO接口的实现类


    Mybatis环境搭建中的案例分析
    public static void main (String[] args) throws Exception {

    //读配置文件
       //第一个: 使用类加载器,只能读取类路径下的文件

    //第二个: 使用ServletContext对象的getRealPath() 获取当前应用部署后的绝对路径
    //1. 读取配置文件
    InputStream inputStream= Resources.getResourceAsStream ("SqlMapConfig.xml");
    //2. 创建一个SqlSessionFactory工厂
    //创建工厂mybatis使用了构建者模式 把对象的创建细节隐藏 使使用者直接调用方法即可拿到对象
    SqlSessionFactoryBuilder sqlSessionFactoryBuilder=new SqlSessionFactoryBuilder ();
    SqlSessionFactory sqlSessionFactory=sqlSessionFactoryBuilder.build (inputStream);
    //3. 使用工厂生产SqlSession对象
    //生产sqlSession使用了工厂模式 优势 解耦
    SqlSession sqlSession=sqlSessionFactory.openSession ();
    //4. 使用SqlSession创建DAO接口的代理对象
    //创建DAO接口实现类使用了代理模式 不修改源码的基础上, 对已有的方法进行增强
    IUserDao userDao=sqlSession.getMapper (IUserDao.class);
    //5. 使用代理对象执行方法
    List<User> users=userDao.findAll ();
    for (User user: users){
    System.out.println (user);
    }
    //6. 释放资源
    sqlSession.close ();
    inputStream.close ();
    }

     如果自己编写DAO接口的实现类

    public class UserDaoImpl implements IUserDao {
        private SqlSessionFactory factory;
        public UserDaoImpl(SqlSessionFactory  factory){
            this.factory = factory;
        }
        public List<User> findAll(){
            //1.使用工厂创建SqlSession对象
            SqlSession session = factory.openSession();
            //2.使用session执行查询所有方法
            List<User> users = session.selectList("com.itheima.dao.IUserDao.findAll");
            session.close();
            //3.返回查询结果   
            return users;
        }
    }
    
    
    //2.使用session执行查询所有方法
    List<User> users = session.selectList("com.itheima.dao.IUserDao.findAll");
    对应如果自己编写DAO接口的实现类
    <mapper namespace="com.itheima.dao.IUserDao">
    <!--配置查询所有-->
    <select id="findAll" resultType="com.itheima.domain.User">
    select * from user
    </select>
    </mapper>
     
  • 相关阅读:
    1、数据加密基础
    cookie——小甜品
    使用SpringBoot开发REST服务
    从编辑距离、BK树到文本纠错
    360影视视频下载
    从Trie树到双数组Trie树
    使用websocket-sharp来创建c#版本的websocket服务
    OFFICE 文档转换为html在线预览
    IDEA+PHP+XDebug调试配置
    HTML5录音控件
  • 原文地址:https://www.cnblogs.com/mkl7/p/10729377.html
Copyright © 2011-2022 走看看