博客
关于我
SpringMVC+Mybatis (动态代理)学习笔记
阅读量:323 次
发布时间:2019-03-04

本文共 4651 字,大约阅读时间需要 15 分钟。

在demomybatis的基础上,新建dao包,持久层,其中有IUserDao接口:

package com.bit.dao;import com.bit.po.user;//因为该接口位于dao层,所以错误的东西应该让客户的页面看到,所以应往上抛Exceptionpublic interface IUserDao {           public int addUser(user user1) throws Exception;        public int modifyUser(int id,user user2)throws Exception;            public int delUser(int id)throws Exception;                public user queryUser(int id)throws  Exception;}

并写其实现类UserDaoImpl:(部分方法略,只体现查找)

package com.bit.dao;import com.bit.po.user;import org.apache.ibatis.io.Resources;import org.apache.ibatis.session.SqlSession;import org.apache.ibatis.session.SqlSessionFactory;import org.apache.ibatis.session.SqlSessionFactoryBuilder;import java.io.IOException;import java.io.InputStream;public class UserDaoImpl implements IUserDao {       //需要使用sqlSessionFactory和sqlSession    private SqlSessionFactory sqlSessionFactory=null;    //无参构造,new UserDaoImpl时也能new SqlSessionFactory    public UserDaoImpl()    {           String mybatisConfigFile="sqlMapConfig.xml";        InputStream is=null;        try {               is=Resources.getResourceAsStream(mybatisConfigFile);            sqlSessionFactory=new SqlSessionFactoryBuilder().build(is);        } catch (IOException e) {               e.printStackTrace();        }    }      @Override    public user queryUser(int id) throws Exception {           SqlSession sqlSession=sqlSessionFactory.openSession();        user user1=sqlSession.selectOne("test.queryUserById",id);        return user1;    }}

新建一个测试类MyBatisTest2,它相当于客户端,此时的测试类中不需要new SqlSessionFactory和SqlSession了:

package com.bit;import com.bit.dao.IUserDao;import com.bit.dao.UserDaoImpl;import com.bit.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.IOException;import java.io.InputStream;public class MybatisTest2 {       //只需要Dao    //此时没有Spring,自行创建   private IUserDao iUserDao=new UserDaoImpl();   @Test    public void queryUser(){   try {       user user1 = iUserDao.queryUser(2);    System.out.println(user1);}catch (Exception ex){   ex.printStackTrace();}}}

运行结果为:

在这里插入图片描述
要用mapper代理的方式开发Mybatis:
静态代理 动态代理 AOP???

接口修改方法如下:

package com.bit.dao;import com.bit.po.user;import java.util.List;//因为该接口位于dao层,所以错误的东西应该让客户的页面看到,所以应往上抛Exceptionpublic interface IUserDao {      public user queryUserById(int myid)throws Exception;      public List
queryUserByName(String name)throws Exception; public void modifyUser(user user1) throws Exception; public void delUser(int id)throws Exception; public user queryUser(int id)throws Exception;}

如果用户有很多个订单,难道需要很多个Impl类? 利用动态代理,代理对象,像反射一样,运行期创建。因此不再需要UserDaoImpl。

那么只剩下接口,没有实现类。——通过代理Proxy,动态代理需要实现一些规则。约定优于配置。

在mapper包下新建user.xml:

>
update user set username=#{ userName} where userid=#{ userID};
delete from user where userid=#{ value};

新建单元测试MybatisTest3:

package com.bit;import com.bit.dao.IUserDao;import com.bit.po.user;import org.apache.ibatis.io.Resources;import org.apache.ibatis.session.SqlSession;import org.apache.ibatis.session.SqlSessionFactory;import org.apache.ibatis.session.SqlSessionFactoryBuilder;import org.junit.Before;import org.junit.Test;import java.io.IOException;import java.io.InputStream;public class MybatisTest3 {       private SqlSessionFactory sqlSessionFactory;    @Before    public void testInit()    {           String mybatisConfigFile="sqlMapConfig.xml";        InputStream is=null;        try {               is=Resources.getResourceAsStream(mybatisConfigFile);            sqlSessionFactory=new SqlSessionFactoryBuilder().build(is);        } catch (IOException e) {               e.printStackTrace();        }    }    //测queryById    //使用mapper动态代理    @Test    public void test()    {   SqlSession sqlSession=sqlSessionFactory.openSession();        //代理对象与被代理对象实现同一接口,所以生成的代理对象也实现了IUserDao这个接口        try        {               IUserDao userDao=sqlSession.getMapper(IUserDao.class);        user user1=userDao.queryUserById(3);        System.out.println(user1);        }        catch (Exception ex)        {   ex.printStackTrace();}        finally {               sqlSession.close();        }    }}

再把user.xml的名字改成与接口名一致,并且放在同一个包下:

在这里插入图片描述
就可以通过包扫描;

可以将dao层改名为mapper层。(现在改名叫mapper了。)

总结:

动态代理实现Mybatis的七个规则

规则1:workspace一致,

2:方法名与id名一致
3.方法参数与ParameterType一致
4.方法返回值与ResultType一致
5.接口与xml名字一致
6.接口与xml在同一个包下
7.通过包扫描

转载地址:http://objh.baihongyu.com/

你可能感兴趣的文章
一些留给自己的思考题(只求回过头来能够有所获)
查看>>
SQL函数返回表的写法
查看>>
delete对象时会自动调用类的析构函数
查看>>
C++ 子类对象直接赋值给父类对象可行,反过来不行
查看>>
WMWare下安装centOS7,并使用xshell进行连接记录.
查看>>
linux下同一个动态库名为何辣么多的.so文件
查看>>
SQL联表的方式(逗号, Left Join, Right Join)
查看>>
牛客网输入输出举例
查看>>
字符串初始化时的注意点
查看>>
dll路径加载顺序
查看>>
悬垂指针和野指针的区别
查看>>
软考相关试题
查看>>
顺序表的操作
查看>>
常量表达式
查看>>
POD类型
查看>>
安装HDF5及在VS下配置HDF5
查看>>
const与常量,傻傻分不清楚~
查看>>
图解哈希表及其原理
查看>>
Head First设计模式——迭代器模式
查看>>
Head First设计模式——中介者模式和备忘录模式
查看>>