Mybatis知识整理(三)Mybatis原始dao开发

  通过上一节的知识整理中我们发现了:

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

  在这一节的整理中,我们首先使用原始dao的方法来进行开发。

(UserDao.java)

 

package com.mybatis.dao;

import com.mybatis.po.User;

/**
 * Created by Administrator on 2018/3/29.
 * 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;

}

(IUserDaoImpl.java)

 

package com.mybatis.dao.impl;

import com.mybatis.dao.UserDao;
import com.mybatis.po.User;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;

/**
 * Created by Administrator on 2018/3/29.
 */
public class IUserDaoImpl implements UserDao {
    //需要向dao实现类中注入SqlSessionFactory
    //这里通过构造方法注入
    private SqlSessionFactory sqlSessionFactory;
    public IUserDaoImpl(SqlSessionFactory sqlSessionFactory){
        this.sqlSessionFactory = sqlSessionFactory;
    }
    @Override
    public User findUserById(int id) throws Exception {
        SqlSession sqlSession = sqlSessionFactory.openSession();
        User user= sqlSession.selectOne("test.findUserById",100);
        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.deleteUserById",id);
        sqlSession.commit();
        sqlSession.close();
    }
}

(IUserDaoImplTest.java)

 

package com.mybatis.test;

import com.mybatis.dao.UserDao;
import com.mybatis.dao.impl.IUserDaoImpl;
import com.mybatis.po.User;
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 java.io.InputStream;

/**
 * Created by Administrator on 2018/3/29.
 */
public class IUserDaoImplTest {
    SqlSessionFactory sqlSessionFactory;
    @Before
    public void setUP() throws Exception{
        //创建sqlSessionFactory
        //mybatis配置文件
        String  resource ="SqlMapConfig.xml";
        // 得到配置文件流
        InputStream inputStream= Resources.getResourceAsStream(resource);
        //创建回话工厂
         sqlSessionFactory =new SqlSessionFactoryBuilder().build(inputStream);

    }
    @Test
    public void testFindUserById() throws Exception {
        //创建UserDao的对象
        UserDao userDao =new IUserDaoImpl(sqlSessionFactory);
        //调用UserDao的方法
        User user=userDao.findUserById(100);
        System.out.println(user);


    }
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值