文档章节

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

M
 Mysoft
发布于 2015/09/17 10:49
字数 898
阅读 245
收藏 0

下面来讨论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());
        
    }
    
}

2.4总结原始 dao开发问题


1、dao接口实现类方法中存在大量模板方法,设想能否将这些代码提取出来,大大减轻程序员的工作量。
2、调用sqlsession方法时将statement的id硬编码了
3、调用sqlsession方法时传入的变量,由于sqlsession方法使用泛型,即使变量类型传入错误,在编译阶段也不报错,不利于程序员开发。


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


本文转载自:http://blog.csdn.net/acmman/article/details/46455507

M
粉丝 4
博文 58
码字总数 24535
作品 0
广州
高级程序员
私信 提问
初学者Mybatis的初级使用

前言:本文章主要分三点内容对于Mybatis的初级使用进行教学,我们因为只是为了实现功能,而不是去了解底层封装原理,因此,我们只需要了解,Mybatis只是用来后端管理sql 管理dao层的框架即可...

zhengzeyuan
2018/11/19
0
0
Mybatis应用学习——简单使用示例

传统JDBC程序中存在的问题 1. 一个简单的JDBC程序示例: 2. 上面代码造成的问题: 频繁的创建和释放数据库连接对象,极大消耗数据库性能,解决:可以通过数据库连接池技术(c3p0、DBCP、dru...

江左煤郎
2018/11/22
21
0
MyBatis 实践 -Mapper与DAO

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/hanqing280441589/article/details/50760236 标签: Java与存储 MyBatis简介 MyBatis前身是iBatis,是一个基于...

菜鸟-翡青
2016/02/28
0
0
mybatis学习笔记(2)-mybatis概述

mybatis学习笔记(2)-mybatis概述 标签: mybatis [TOC] 本文对mybatis做一个简单介绍,包括框架原理,执行过程,开发方法,输入输出映射以及动态sql,我会在后续的系列文章中一一详细说明 my...

brianway
2016/02/27
465
0
【MyBatis框架】Mybatis开发dao方法第二部分

下面来继续讨论mybatis开发Dao的方法 我们前面使用原始的Dao开发方法,发现了许多弊端,我们下面使用mapper代理来写Dao方法。 1.mapper代理方法(程序员只需要mapper接口(相当 于dao接口))...

Mysoft
2015/09/17
125
0

没有更多内容

加载失败,请刷新页面

加载更多

Mybatis Plus删除

/** @author beth @data 2019-10-17 00:30 */ @RunWith(SpringRunner.class) @SpringBootTest public class DeleteTest { @Autowired private UserInfoMapper userInfoMapper; /** 根据id删除......

一个yuanbeth
今天
4
0
总结

一、设计模式 简单工厂:一个简单而且比较杂的工厂,可以创建任何对象给你 复杂工厂:先创建一种基础类型的工厂接口,然后各自集成实现这个接口,但是每个工厂都是这个基础类的扩展分类,spr...

BobwithB
今天
4
0
java内存模型

前言 Java作为一种面向对象的,跨平台语言,其对象、内存等一直是比较难的知识点。而且很多概念的名称看起来又那么相似,很多人会傻傻分不清楚。比如本文我们要讨论的JVM内存结构、Java内存模...

ls_cherish
今天
4
0
友元函数强制转换

友元函数强制转换 p522

天王盖地虎626
昨天
5
0
js中实现页面跳转(返回前一页、后一页)

本文转载于:专业的前端网站➸js中实现页面跳转(返回前一页、后一页) 一:JS 重载页面,本地刷新,返回上一页 复制代码代码如下: <a href="javascript:history.go(-1)">返回上一页</a> <a h...

前端老手
昨天
5
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部