Mybatis源碼分析之存儲(chǔ)過程調(diào)用和運(yùn)行流程
這一篇我們學(xué)習(xí)一下Mybatis調(diào)用存儲(chǔ)過程的使用和運(yùn)行流程。首先我們先創(chuàng)建一個(gè)簡(jiǎn)單的存儲(chǔ)過程
DELIMITER $ CREATE PROCEDURE mybatis.ges_user_count(IN age INT, OUT user_count INT) BEGIN SELECT COUNT(*) FROM users WHERE users.age=age INTO user_count; END $
這個(gè)存儲(chǔ)過程的含義其實(shí)比較簡(jiǎn)單的,就是輸入age,然后執(zhí)行select count(*) from users where users.age = age into user_count;獲得年齡等于age的人數(shù)賦值給user_count,還是比較簡(jiǎn)單的。
接下來是存儲(chǔ)過程的調(diào)用,執(zhí)行如下命令就可以完成存儲(chǔ)過程的調(diào)用。
接下來我們看看利用Mybatis是如何調(diào)用存儲(chǔ)過程的。
userMapper.xml添加存儲(chǔ)過程調(diào)用配置:
<select id="count" statementType="CALLABLE" parameterMap="getUserCountMap"> CALL mybatis.ges_user_count(?,?) </select>
Main函數(shù):
public class Learn1Main { public static void main(String [] args){ //mybatis的配置文件 String resource = "learn/mybatis-config.xml"; //使用類加載器加載mybatis的配置文件(它也加載關(guān)聯(lián)的映射文件) InputStream is = Learn1Main.class.getClassLoader().getResourceAsStream(resource); //構(gòu)建sqlSession的工廠 SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(is); SqlSession session = sessionFactory.openSession(); Map<String, Integer> parameterMap = new HashMap<String, Integer>(); parameterMap.put("age", 12); parameterMap.put("user_count", -1); session.selectOne("com.tianjunwei.learn.learn1.entity.User.count", parameterMap); Integer result = parameterMap.get("user_count"); System.out.println(result); } }
運(yùn)行結(jié)果:
其最終的執(zhí)行過程在DefaultResultSetHandler中,調(diào)用普通的sql和存儲(chǔ)過程之間還是有所區(qū)別的,Sql語句的執(zhí)行是使用CallableStatement。
// // HANDLE OUTPUT PARAMETER // //調(diào)用存儲(chǔ)過程返回結(jié)果,將結(jié)果值放在參數(shù)中 @Override public void handleOutputParameters(CallableStatement cs) throws SQLException { final Object parameterObject = parameterHandler.getParameterObject(); final MetaObject metaParam = configuration.newMetaObject(parameterObject); final List<ParameterMapping> parameterMappings = boundSql.getParameterMappings(); /循環(huán)處理每個(gè)參數(shù) for (int i = 0; i < parameterMappings.size(); i++) { final ParameterMapping parameterMapping = parameterMappings.get(i); //判斷參數(shù)的模式 if (parameterMapping.getMode() == ParameterMode.OUT || parameterMapping.getMode() == ParameterMode.INOUT) { if (ResultSet.class.equals(parameterMapping.getJavaType())) { handleRefCursorOutputParameter((ResultSet) cs.getObject(i + 1), parameterMapping, metaParam); } else { final TypeHandler<?> typeHandler = parameterMapping.getTypeHandler(); metaParam.setValue(parameterMapping.getProperty(), typeHandler.getResult(cs, i + 1)); } } } } private void handleRefCursorOutputParameter(ResultSet rs, ParameterMapping parameterMapping, MetaObject metaParam) throws SQLException { try { final String resultMapId = parameterMapping.getResultMapId(); final ResultMap resultMap = configuration.getResultMap(resultMapId); final DefaultResultHandler resultHandler = new DefaultResultHandler(objectFactory); final ResultSetWrapper rsw = new ResultSetWrapper(rs, configuration); handleRowValues(rsw, resultMap, resultHandler, new RowBounds(), null); metaParam.setValue(parameterMapping.getProperty(), resultHandler.getResultList()); } finally { // issue #228 (close resultsets) closeResultSet(rs); } }
以上所述是小編給大家介紹的Mybatis源碼分析之存儲(chǔ)過程調(diào)用和運(yùn)行流程,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
- Mybatis SQL運(yùn)行流程源碼詳解
- 使用MyBatisPlus自動(dòng)生成代碼后tomcat運(yùn)行報(bào)錯(cuò)的問題及解決方法
- Mybatis逆向工程運(yùn)行代碼實(shí)例
- Mybatis工具類JdbcTypeInterceptor運(yùn)行時(shí)自動(dòng)添加jdbcType屬性
- 詳解MyBatis工作原理
- MyBatis緩存實(shí)現(xiàn)原理及代碼實(shí)例解析
- Mybatis Mapper接口工作原理實(shí)例解析
- 簡(jiǎn)單了解mybatis攔截器實(shí)現(xiàn)原理及實(shí)例
- 分析mybatis運(yùn)行原理
相關(guān)文章
java實(shí)現(xiàn)圖片的上傳與展示實(shí)例代碼
這篇文章主要給大家介紹了關(guān)于java實(shí)現(xiàn)圖片的上傳與展示的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-12-12JavaEE組件commons-fileupload實(shí)現(xiàn)文件上傳、下載
這篇文章主要介紹了JavaEE組件commons-fileupload實(shí)現(xiàn)文件上傳、下載,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-10-10itext生成PDF設(shè)置頁眉頁腳的實(shí)例詳解
這篇文章主要介紹了itext生成PDF設(shè)置頁眉頁腳的實(shí)例詳解的相關(guān)資料,希望通過本文能幫助到大家,需要的朋友可以參考下2017-09-09Java集合ArrayList、LinkedList、HashMap、HashSet最大容量
在開發(fā)中我們使用比較多的集合就是List、Set和Map了,并且我們也知道大部分用的基本上都是ArrayList、LinkedList、HashMap、HashSet或者TreeSet這幾個(gè)集合,你知道他們的最大容量,感興趣的可以了解一下2023-12-12java實(shí)現(xiàn)液晶數(shù)字字體顯示當(dāng)前時(shí)間
這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)液晶數(shù)字字體顯示當(dāng)前時(shí)間,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-12-12詳解Java去除json數(shù)據(jù)中的null空值問題
這篇文章主要介紹了詳解Java去除json數(shù)據(jù)中的null空值問題,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08