这一篇我们学习一下Mybatis调用存储过程的使用和运行流程。首先我们先创建一个简单的存储过程
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,然后执行select count(*) from users where users.age = age into user_count;获得年龄等于age的人数赋值给user_count,还是比较简单的。
接下来是存储过程的调用,执行如下命令就可以完成存储过程的调用。
接下来我们看看利用Mybatis是如何调用存储过程的。
userMapper.xml添加存储过程调用配置:
<select id="count" statementType="CALLABLE" parameterMap="getUserCountMap"> CALL mybatis.ges_user_count(?,?) </select>
Main函数:
public class Learn1Main { public static void main(String [] args){ //mybatis的配置文件 String resource = "learn/mybatis-config.xml"; //使用类加载器加载mybatis的配置文件(它也加载关联的映射文件) 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); } }
运行结果:
其最终的执行过程在DefaultResultSetHandler中,调用普通的sql和存储过程之间还是有所区别的,Sql语句的执行是使用CallableStatement。
// // HANDLE OUTPUT PARAMETER // //调用存储过程返回结果,将结果值放在参数中 @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(); /循环处理每个参数 for (int i = 0; i < parameterMappings.size(); i++) { final ParameterMapping parameterMapping = parameterMappings.get(i); //判断参数的模式 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源码分析之存储过程调用和运行流程,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对小牛知识库网站的支持!
本文向大家介绍PHP源码分析之变量的存储过程分解,包括了PHP源码分析之变量的存储过程分解的使用技巧和注意事项,需要的朋友参考一下 PHP代码如下: 对应C的代码是: 一.首先看第一行: zval* c_var;//申明一个zval指针c_var; zval的结构如下: 其中值zvalue_value的结构如下: 二.接下来看第二行: MAKE_STD_ZVAL(new_val);//变量初始化
本文向大家介绍java调用mysql存储过程实例分析,包括了java调用mysql存储过程实例分析的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了java调用mysql存储过程的方法。分享给大家供大家参考。具体如下: 数据库的测试代码如下 : 1、新建表test 2、删除已存在的存储过程: 3、mysql存储过程定义: 4、调用方法: 希望本文所述对大家的java程序设计有所帮助。
本文向大家介绍php调用mysql存储过程实例分析,包括了php调用mysql存储过程实例分析的使用技巧和注意事项,需要的朋友参考一下 本文实例分析了php调用mysql存储过程的方法。分享给大家供大家参考。具体分析如下: Mysql存储过程创建语法,代码如下: CREATE PROCEDURE和CREATE FUNCTION : 当我们看完以后,就可以开始写一些简单的存储过程了,首先建立存储过程
问题内容: 我一直想知道如何将所有存储过程放在源代码管理下的SQL 2000上。 我们将Subversion用于所有常规源代码,因此,如果有使用Subversion解决该问题的方法,那就更好了。 你有什么想法? 更新16-02-2009:这是我用来导出所有存储过程的vbs脚本: 问题答案: 就像其他人所说的那样,首先将每个存储的proc存储在一个单独的文本文件中,该文件受源代码控制。写一个脚本来删
我是Python的新手。我正在使用apache airflow和一个我称之为存储过程oracle的任务。我看到错误非法变量名称/数字 [2019-08-2918:09:21089]{dbapi_hook.py:168}信息-开始生效();终止带有参数('1','TC','ESPA','99','2','100','28-08-2019','0')[2019-08-29 18:09:21091]{i
问题内容: 我试图在postgres 9.3上使用sql调用函数内的函数。 这个问题与我的另一篇文章有关。 我写了下面的函数。到目前为止,我还没有合并任何类型的save-output(COPY)语句,因此我试图通过创建嵌套函数print-out函数来解决此问题。 以上功能有效。 尝试创建嵌套函数。 调用嵌套函数。 输出 上面给出了这个。但是,当在print_out()中将arg1,arg2替换为’