国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

詳解Mybatis內的mapper方法為何不能重載

瀏覽:120日期:2023-10-20 15:32:21

動態代理的功能:通過攔截器方法回調,對目標target方法進行增強。

言外之意就是為了增強目標target方法。上面這句話沒錯,但也不要認為它就是真理,殊不知,動態代理還有投鞭斷流的霸權,連目標target都不要的科幻模式。

注:本文默認認為,讀者對動態代理的原理是理解的,如果不明白target的含義,難以看懂本篇文章,建議先理解動態代理。

1. 自定義JDK動態代理之投鞭斷流實現自動映射器Mapper

首先定義一個pojo。

public class User { private Integer id; private String name; private int age; public User(Integer id, String name, int age) { this.id = id; this.name = name; this.age = age; } // getter setter}

再定義一個接口UserMapper.java。

public interface UserMapper { public User getUserById(Integer id); }

接下來我們看看如何使用動態代理之投鞭斷流,實現實例化接口并調用接口方法返回數據的。

自定義一個InvocationHandler。

import java.lang.reflect.InvocationHandler;import java.lang.reflect.Method;import java.lang.reflect.Proxy;public class MapperProxy implements InvocationHandler { @SuppressWarnings('unchecked') public <T> T newInstance(Class<T> clz) { return (T) Proxy.newProxyInstance(clz.getClassLoader(), new Class[] { clz }, this); } @Override public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { if (Object.class.equals(method.getDeclaringClass())) { try { // 諸如hashCode()、toString()、equals()等方法,將target指向當前對象this return method.invoke(this, args); } catch (Throwable t) { } } // 投鞭斷流 return new User((Integer) args[0], 'zhangsan', 18); }}

上面代碼中的target,在執行Object.java內的方法時,target被指向了this,target已經變成了傀儡、象征、占位符。在投鞭斷流式的攔截時,已經沒有了target。

寫一個測試代碼:

public static void main(String[] args) { MapperProxy proxy = new MapperProxy(); UserMapper mapper = proxy.newInstance(UserMapper.class); User user = mapper.getUserById(1001); System.out.println('ID:' + user.getId()); System.out.println('Name:' + user.getName()); System.out.println('Age:' + user.getAge()); System.out.println(mapper.toString());}

output:

ID:1001Name:zhangsanAge:18 pagex.y.MapperProxy@6bc7c054

這便是Mybatis自動映射器Mapper的底層實現原理。

可能有讀者不禁要問:你怎么把代碼寫的像初學者寫的一樣?沒有結構,且缺乏美感。

必須聲明,作為一名經驗老道的高手,能把程序寫的像初學者寫的一樣,那必定是高手中的高手。這樣可以讓初學者感覺到親切,舒服,符合自己的Style,讓他們或她們,感覺到大牛寫的代碼也不過如此,自己甚至寫的比這些大牛寫的還要好,從此自信滿滿,熱情高漲,認為與大牛之間的差距,僅剩下三分鐘。

2. Mybatis自動映射器Mapper的源碼分析

首先編寫一個測試類:

public static void main(String[] args) { SqlSession sqlSession = MybatisSqlSessionFactory.openSession(); try { StudentMapper studentMapper = sqlSession.getMapper(StudentMapper.class); List<Student> students = studentMapper.findAllStudents(); for (Student student : students) { System.out.println(student); } } finally { sqlSession.close(); } }

Mapper長這個樣子:

public interface StudentMapper { List<Student> findAllStudents(); Student findStudentById(Integer id); void insertStudent(Student student);}

org.apache.ibatis.binding.MapperProxy.java部分源碼。

public class MapperProxy<T> implements InvocationHandler, Serializable { private static final long serialVersionUID = -6424540398559729838L; private final SqlSession sqlSession; private final Class<T> mapperInterface; private final Map<Method, MapperMethod> methodCache; public MapperProxy(SqlSession sqlSession, Class<T> mapperInterface, Map<Method, MapperMethod> methodCache) { this.sqlSession = sqlSession; this.mapperInterface = mapperInterface; this.methodCache = methodCache; } @Override public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { if (Object.class.equals(method.getDeclaringClass())) { try { return method.invoke(this, args); } catch (Throwable t) { throw ExceptionUtil.unwrapThrowable(t); } } // 投鞭斷流 final MapperMethod mapperMethod = cachedMapperMethod(method); return mapperMethod.execute(sqlSession, args); } // ...

org.apache.ibatis.binding.MapperProxyFactory.java部分源碼。

public class MapperProxyFactory<T> { private final Class<T> mapperInterface; @SuppressWarnings('unchecked') protected T newInstance(MapperProxy<T> mapperProxy) { return (T) Proxy.newProxyInstance(mapperInterface.getClassLoader(), new Class[] { mapperInterface }, mapperProxy); }

這便是Mybatis使用動態代理之投鞭斷流。

3. 接口Mapper內的方法能重載(overLoad)嗎?(重要)

類似下面:

public User getUserById(Integer id);public User getUserById(Integer id, String name);

Answer:不能。

原因:在投鞭斷流時,Mybatis使用package+Mapper+method全限名作為key,去xml內尋找唯一sql來執行的。類似:key=x.y.UserMapper.getUserById,那么,重載方法時將導致矛盾。對于Mapper接口,Mybatis禁止方法重載(overLoad)。

注:學習時,是先研究的源碼,看懂了原理。寫博文時,則先闡釋原理,再閱讀的源碼。順序剛好相反,希望讀者不要因此疑惑,以為我強大到未卜先知。

到此這篇關于詳解Mybatis內的mapper方法為何不能重載的文章就介紹到這了,更多相關Mybatis mapper重載內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Mybatis 數據庫
相關文章:
主站蜘蛛池模板: 亚洲精品成人一区二区 | 国产伦精品一区三区视频 | 国产人成久久久精品 | 成人欧美视频在线观看播放 | 女人张开腿让男人桶视频 | 国产色爽女小说免费看 | 久久国产精品永久免费网站 | 特黄特黄一级高清免费大片 | 欧美色成人综合 | 特黄特黄黄色大片 | 手机在线观看亚洲国产精品 | 日韩一区二区三区四区不卡 | 自拍在线视频 | 国产精品久久久久国产精品三级 | 日韩三级在线观看视频 | 9久9久女女热精品视频免费观看 | 国产一区二区三区四区波多野结衣 | 另类专区另类专区亚洲 | 日韩欧美一区二区中文字幕 | 国产精品视频久久久久久 | 欧美成人午夜不卡在线视频 | 午夜美女久久久久爽久久 | 韩国一级永久免费观看网址 | 欧美成年黄网站色高清视频 | 亚洲精品欧洲一区二区三区 | 欧美毛片大全 | 99精品偷自拍 | 国产一区二区影视 | 欧美日本综合一区二区三区 | 欧美精品成人久久网站 | 国产精品一二三区 | 欧美性另类69xxxx极品 | 国产精品黄色 | 一区二区免费看 | 亚洲免费三级 | 亚洲国产三级在线观看 | 日韩一区二区三区精品 | 中文字幕精品一区二区2021年 | 中文字幕亚洲综合久久 | 视频一区欧美 | 久热精品男人的天堂在线视频 |