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>
     
  • 相关阅读:
    很漂亮的按钮css样式(没有用到图片,可直接拷贝代码使用)
    if、while中变量的作用域问题
    笔记
    搭建高可用mongodb集群(一)——配置mongodb
    Java编程:删除 List 元素的三种正确方法
    MySQL 数据类型
    MySQL 通用查询日志(General Query Log)
    mysql 创建一个用户,指定一个数据库
    MySQL 5.7 免安装版配置
    String,StringBuffer与StringBuilder的区别??
  • 原文地址:https://www.cnblogs.com/mkl7/p/10729377.html
Copyright © 2011-2022 走看看