IBatis 调用存储过程

http://www.cnblogs.com/jeffwongishandsome/archive/2010/01/10/1543219.html

http://www.cnblogs.com/firstyi/archive/2008/01/25/1053208.html

存储过程大致分为两种:

  • 查询类存储过程——select查询类的存储过程,不曾改变数据库数据的存储过程
  • 更新类存储过程——Update/Insert/Delete类型的存储过程,改变数据库数据的存储过程

IBatis.net调用存储过程:

1、查询类型的存储过程

创建一个查询类存储过程,其中包含output参数。

CREATE PROCEDURE up_GetCountByTitle
    @title VARCHAR()    ,
    @total INT OUT
    AS
    BEGIN
        WITH a AS (
        SELECT * FROM Article a WHERE a.ArticleTitle LIKE '%'+@title+'%')
        SELECT @total=COUNT(*) FROM a
    END

获取总数的存储过程

XML文件,如果包含输出参数,输出参数属性值,必须包含column属性。

<?xml version="1.0" encoding="utf-8" ?>
<sqlMap namespace="Article"
    xmlns="http://ibatis.apache.org/mapping"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">

  <alias>
    <typeAlias alias="Article" type="YY.MicroNet.Model.Article,YY.MicroNet.Model"/>
  </alias>

  <resultMaps>
    <resultMap id="FullResultMap" class="Article">
      <result property="PKArticle" column="PK_Article" dbType="VarChar"/>
      <result property="ArticleTitle" column="ArticleTitle" dbType="NVarChar"/>
      <result property="ArticleAuthor" column="ArticleAuthor" dbType="NVarChar"/>
      <result property="ArticleContent" column="ArticleContent" dbType="NVarChar"/>
      <result property="EditTime" column="EditTime" dbType="DateTime"/>
      <result property="Dr" column="Dr" dbType="Bit"/>
      <result property="Ts" column="Ts" dbType="DateTime"/>
    </resultMap>
    <parameterMaps>
      <!--parameterMap中的参数个数和顺序要和up_GetCountByTitle存储过程中的一致-->
      <parameterMap id="params" class="Hashtable">
        <parameter property="title" />
        <parameter property="total" column="total" direction="Output"/>
      </parameterMap>
    </parameterMaps>
  </resultMaps>

  <statements>
    <!--调用查询类型的存储过程-->
    <procedure id="Article_GetCountByTitle" parameterMap="" resultClass="System.Int32">
      up_GetCountByTitle
    </procedure>
  </statements>
</sqlMap>

ArticleMap.xml

在cs中调用

        public IList<Article> GetCountByTitle(Hashtable ht)
        {
            String stmtId = "Article_GetCountByTitle";
            IList<Article> result = SqlMap.QueryForList<Article>(stmtId,  ht);
            return result;
        }

  

IBatis.Net使用总结(四)-- IBatis 调用存储过程的更多相关文章

  1. Java和Ibatis调用存储过程并取得返回值详解

    Java和Ibatis调用存储过程并取得返回值详解 2011-07-19 17:33 jiandanfeng2 CSDN博客 字号:T | T 本文主要介绍了Java和Ibatis调用存储过程的方法, ...

  2. MySQL 存储过程实例 与 ibatis/mybatis/hibernate/jdbc 如何调用存储过程

    虽然MySQL的存储过程,一般情况下,是不会使用到的,但是在一些特殊场景中,还是有需求的.最近遇到一个sql server向mysql迁移的项目,有一些sql server的存储过程需要向mysql迁 ...

  3. iBatis调用存储过程以及MySQL创建存储过程

    首先是MySQL中创建存储过程的SQL -- 列出全部的存储过程 SHOW PROCEDURE STATUS; -- 查看一个已存在的存储过程的创建语句,假设此存储过程不存在,会提示SQL错误(130 ...

  4. Ibatis调用存储过程实现增删改以及分页查询

    1.Ibatis实现增删改操作很简单了,通常我是将某一模块的增删改功能写在一个存储过程里,通过一个标识符去区分执行增加还是修改抑或删除操作. statement: <!-- 存储过程:实现学生的 ...

  5. ibatis 调用存储过程

      ibatis 调用存储过程 CreationTime--2018年8月15日19点38分 Author:Marydon 1.返回系统游标集合 第一步:返回值,将返回值封装到HashMap中 < ...

  6. ibatis调用存储过程(无返回参数)

    ibatis调用存储过程例子: java: getSqlMapClientTemplate().insert(sql, paraMap) ibatis xml: <parameterMap id ...

  7. ASP.NET MVC深入浅出(被替换) 第一节: 结合EF的本地缓存属性来介绍【EF增删改操作】的几种形式 第三节: EF调用普通SQL语句的两类封装(ExecuteSqlCommand和SqlQuery ) 第四节: EF调用存储过程的通用写法和DBFirst模式子类调用的特有写法 第六节: EF高级属性(二) 之延迟加载、立即加载、显示加载(含导航属性) 第十节: EF的三种追踪

    ASP.NET MVC深入浅出(被替换)   一. 谈情怀-ASP.NET体系 从事.Net开发以来,最先接触的Web开发框架是Asp.Net WebForm,该框架高度封装,为了隐藏Http的无状态 ...

  8. [原创]java WEB学习笔记79:Hibernate学习之路--- 四种对象的状态,session核心方法:save()方法,persist()方法,get() 和 load() 方法,update()方法,saveOrUpdate() 方法,merge() 方法,delete() 方法,evict(),hibernate 调用存储过程,hibernate 与 触发器协同工作

    本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱 ...

  9. 第四节: EF调用存储过程的通用写法和DBFirst模式子类调用的特有写法

    一. 背景 上一个章节,介绍了EF调用两类SQL语句,主要是借助 ExecuteSqlCommand  和 SqlQuery 两个方法来完成,在本章节主要是复习几类存储过程的写法和对应的EF调用这几类 ...

随机推荐

  1. Java 引用分类:StrongReference、SoftReference、WeakReference、PhantomReference

    一,定义 在Java中,引用的定义是:如果reference类型的数据中存储的数值代表的是另一块内存的起始地址,就称这块内存代表着一个引用.后面在JDK1.2开始,引用的概念被扩充,引用被分为强引用( ...

  2. Bubble Cup 8 finals D. Tablecity (575D)

    题意: (无输入,纯输出题) 一个城市用1000列2行的格子表示,一个小偷藏在城市的某一处. 在每一小时的开始, 在(X, Y)位置的小偷可以移动到 (X - 1, Y), (X + 1, Y),(X ...

  3. Bubble Cup 8 finals A. Fibonotci (575A)

    题意: 定义类循环序列为 长度无限,且除了有限个元素外,均满足s[i] ≡ s[i mod N] (i≥N). 现在有数列F,定义为 F[i] = s[i-2]*F[i-1] + s[i-1]*F[i ...

  4. Excel——OFFSET函数

    1.首先看下offset函数的参数设置: 说明:height,width表面它的返回值可以是一个数组,而并非一个值.这样,它就可以用于数据有效性等. 2.使用offset实现转置: 3.offset函 ...

  5. 利用JS实现点击按钮后图片自动切换

    我么常常看到一个网站的主界面的图片可以切换自如,那么又是如何实现的呢? 1.HTML页面布局如图所示: Main(div) top(div)(显示需要显示的图片) bottom UL (li)< ...

  6. 两台win7电脑网线直连办法(共享文件夹形式)

    一.背景 一台电脑需要测试,但要不停更新APP,可是该电脑没网络,用U盘太繁琐,即想到用网线将两台 电脑直连,一台电脑共享文件夹给另一台电脑,达到交换文件的目的. 感谢Tony(http://www. ...

  7. 推荐eclipse插件Properties Editor

    需求:一般我们在做"国际化"功能时,我们需要properties中文表示方式用unicode表示.eclipse默认properties文件编辑器不方便查看,需要我们查看常常查找u ...

  8. 4. K线经典组合及意义一

    一. K线的三种形态: 1. 上升形态 2. 下跌形态 3. 顶部及底部形态 二. K线组合三大类 1. 上升形态,当这种K线或K线组合出现,表示股价要上涨. 2. 下跌形态,当这种K线或K线组合出现 ...

  9. Sql Server函数全解<二>数学函数

    阅读目录 1.绝对值函数ABS(x)和返回圆周率的函数PI() 2.平方根函数SQRT(x) 3.获取随机函数的函数RAND()和RAND(x) 4.四舍五入函数ROUND(x,y) 5.符号函数SI ...

  10. Picard报错“MAPQ should be 0 for unmapped read”的解决方法

    picard对bwa生成的sam文件进行reorder时,报错如下: Getting Help Exception in thread "main" htsjdk.samtools ...