【MyBatis框架】Mybatis开发dao方法第一部分

下面来讨论mybatis开发Dao的方法

先来说一下基本架构流程中使用到的几个类

1.SqlSession使用范围

1.1SqlSessionFactoryBuilder

1.1SqlSessionFactoryBuilder
 通过SqlSessionFactoryBuilder创建会话工厂SqlSessionFactory
将SqlSessionFactoryBuilder当成一个工具类使用即可,不需要使用单例管理SqlSessionFactoryBuilder。
在需要创建SqlSessionFactory时候,只需要new一次SqlSessionFactoryBuilder即可。

1.2 SqlSessionFactory
通过SqlSessionFactory创建SqlSession,使用单例模式管理sqlSessionFactory(工厂一旦创建,使用一个实例)。

将来mybatis和spring整合后,使用单例模式管理sqlSessionFactory。

1.3SqlSession
SqlSession是一个面向用户(程序员)的接口。
SqlSession中提供了很多操作数据库的方法:如:selectOne(返回单个对象)、selectList(返回单个或多个对象)。

SqlSession是线程不安全的,在SqlSesion实现类中除了有接口中的方法(操作数据库的方法)还有数据域属性。

SqlSession最佳应用场合在方法体内,定义成局部变量使用。

接下来就来说说MyBatis的Dao的写法,分为两种,一种是原始Dao开发方法,一种是mapper代理方法,我们下面一一讨论:
2.原始dao开发方法(程序员需要写dao接口和dao实现类)

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

下面实现Dao的场景是基于之前对用户数据进行增删改查的需求。

2.2写Dao接口

package cn.edu.hpu.mybatis.dao;  
  
import cn.edu.hpu.mybatis.PO.User;  
  
//用户管理的Dao接口  
public interface UserDao {  
      
    //根据Id查询用户信息  
    public User findUserById(int id) throws Exception;  
      
    //添加用户信息  
    public void insertUser(User user) throws Exception;  
      
    //删除用户信息  
    public void deleteUser(int id) throws Exception;  
      
    //修改用户信息  
    public void updateUser(User user) throws Exception;  
}  

2.3写Dao的实现

package cn.edu.hpu.mybatis.dao;  
  
import org.apache.ibatis.session.SqlSession;  
import org.apache.ibatis.session.SqlSessionFactory;  
  
import cn.edu.hpu.mybatis.PO.User;  
  
public class UserDaoImpl implements UserDao{  
  
    //需要向dao实现类中注入SqlSessionFactory工厂  
    //这里我们暂时没用spring,我们通过构造方法注入  
    private SqlSessionFactory sqlSessionFactory;  
    public UserDaoImpl(SqlSessionFactory sqlSessionFactory){  
        this.sqlSessionFactory=sqlSessionFactory;  
    }  
      
    @Override  
    public void deleteUser(int id) throws Exception {  
          
        SqlSession sqlSession=sqlSessionFactory.openSession();  
          
        //传入id删除用户  
        sqlSession.delete("test.deleteUser",id);  
          
        //提交事务  
        sqlSession.commit();  
          
        sqlSession.close();  
    }  
  
  
    @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 updateUser(User user) throws Exception {  
          
        SqlSession sqlSession=sqlSessionFactory.openSession();  
          
        sqlSession.update("test.updateUser",user);  
          
        //提交事务  
        sqlSession.commit();  
          
        sqlSession.close();  
          
    }  
  
  
}  

测试方法(这里只测试findUserBiId方法):

package cn.edu.hpu.mybatis.test;  
  
import java.io.InputStream;  
  
import org.apache.ibatis.io.Resources;  
import org.apache.ibatis.session.SqlSessionFactory;  
import org.apache.ibatis.session.SqlSessionFactoryBuilder;  
import org.junit.Before;  
import org.junit.Test;  
  
  
import cn.edu.hpu.mybatis.PO.User;  
import cn.edu.hpu.mybatis.dao.UserDao;  
import cn.edu.hpu.mybatis.dao.UserDaoImpl;  
  
  
public class UserDaoImplTest {  
  
  
    private SqlSessionFactory sqlSessionFactory;  
      
    //注解Before是在执行本类所有测试方法之前先调用这个方法  
    @Before  
    public void setup() throws Exception{  
        //创建SqlSessionFactory  
        String resource="SqlMapConfig.xml";  
          
        //将配置文件加载成流  
        InputStream inputStream = Resources.getResourceAsStream(resource);  
        //创建会话工厂,传入mybatis配置文件的信息  
        sqlSessionFactory=new SqlSessionFactoryBuilder().build(inputStream);  
    }  
      
    @Test  
    public void testFindUserById() throws Exception{  
          
        //创建Dao对象  
        UserDao userDao=new UserDaoImpl(sqlSessionFactory);  
          
        //调用UserDao的方法  
        User user=userDao.findUserById(1);  
          
        System.out.println(user.getUsername());  
          
    }  
      
}  
测试结果:
张三

输出的日志:

DEBUG [main] - Logging initialized using 'class org.apache.ibatis.logging.slf4j.Slf4jImpl' adapter.  
DEBUG [main] - PooledDataSource forcefully closed/removed all connections.  
DEBUG [main] - PooledDataSource forcefully closed/removed all connections.  
DEBUG [main] - PooledDataSource forcefully closed/removed all connections.  
DEBUG [main] - PooledDataSource forcefully closed/removed all connections.  
DEBUG [main] - Opening JDBC Connection  
DEBUG [main] - Created connection 28970806.  
DEBUG [main] - Setting autocommit to false on JDBC Connection [com.mysql.jdbc.Connection@1ba0f36]  
DEBUG [main] - ==>  Preparing: SELECT * FROM USER WHERE id=?   
DEBUG [main] - ==> Parameters: 1(Integer)  
DEBUG [main] - <==      Total: 1  
DEBUG [main] - Resetting autocommit to true on JDBC Connection [com.mysql.jdbc.Connection@1ba0f36]  
DEBUG [main] - Closing JDBC Connection [com.mysql.jdbc.Connection@1ba0f36]  
DEBUG [main] - Returned connection 28970806 to pool.  

2.4总结原始 dao开发问题
1、dao接口实现类方法中存在大量模板方法,设想能否将这些代码提取出来,大大减轻程序员的工作量。


2、调用sqlsession方法时将statement的id硬编码了


3、调用sqlsession方法时传入的变量,由于sqlsession方法使用泛型,即使变量类型传入错误,在编译阶段也不报错,不利于程序员开发。




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值