您的位置:首页 > 其它

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

2015-06-11 11:39 597 查看
下面来讨论mybatis开发Dao的方法

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

1.SqlSession使用范围

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方法使用泛型,即使变量类型传入错误,在编译阶段也不报错,不利于程序员开发。

下一篇总结我们来使用mapper代理方法来写Dao,来解决上面我们发现的问题。

转载请注明出处:http://blog.csdn.net/acmman/article/details/46455507
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: