国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Java > 正文

Mybatis源碼分析之存儲過程調(diào)用和運行流程

2019-11-26 13:33:00
字體:
供稿:網(wǎng)友

這一篇我們學習一下Mybatis調(diào)用存儲過程的使用和運行流程。首先我們先創(chuàng)建一個簡單的存儲過程

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 $ 

這個存儲過程的含義其實比較簡單的,就是輸入age,然后執(zhí)行select count(*) from users where users.age = age into user_count;獲得年齡等于age的人數(shù)賦值給user_count,還是比較簡單的。

接下來是存儲過程的調(diào)用,執(zhí)行如下命令就可以完成存儲過程的調(diào)用。

接下來我們看看利用Mybatis是如何調(diào)用存儲過程的。

userMapper.xml添加存儲過程調(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的配置文件(它也加載關聯(lián)的映射文件)   InputStream is = Learn1Main.class.getClassLoader().getResourceAsStream(resource);   //構建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);  } } 

運行結(jié)果:

其最終的執(zhí)行過程在DefaultResultSetHandler中,調(diào)用普通的sql和存儲過程之間還是有所區(qū)別的,Sql語句的執(zhí)行是使用CallableStatement。

// // HANDLE OUTPUT PARAMETER // //調(diào)用存儲過程返回結(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)處理每個參數(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源碼分析之存儲過程調(diào)用和運行流程,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網(wǎng)網(wǎng)站的支持!

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 阿城市| 同心县| 蓬溪县| 纳雍县| 中宁县| 奉贤区| 襄垣县| 城口县| 通道| 扎赉特旗| 资阳市| 河西区| 永善县| 临武县| 邻水| 施秉县| 四川省| 昌乐县| 汾阳市| 商洛市| 岳阳县| 长寿区| 承德县| 临夏县| 青州市| 仁怀市| 锡林郭勒盟| 通化市| 阳山县| 卓资县| 长白| 咸丰县| 巩留县| 石家庄市| 万荣县| 桦甸市| 玉屏| 伊春市| 怀安县| 邛崃市| 新乐市|