ibatis 存储过程写法
<?xml version="1.0" encoding="utf-8" ?>
<sqlMap namespace="DepartmentInfoModel" xmlns="http://ibatis.apache.org/mapping" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" > <alias>
<typeAlias alias="DepartmentInfoModel" type="Dscf.Global.Employee.Model.DepartmentInfoModel,Dscf.Global" />
</alias> <!--门店树 传参-->
<parameterMaps>
<parameterMap id="selectMap_Dept_DeptInfo" class="DepartmentInfoModel">
<parameter property="Idenid" column="Idenid"/>
</parameterMap>
</parameterMaps> <resultMaps>
<resultMap id="selectMap_T_DepartmentInfo" class="DepartmentInfoModel">
<result property="DepId" column="DepId"/>
<result property="DepName" column="DepName"/>
<result property="ParentDepId" column="ParentDepId"/>
<result property="DepCode" column="DepCode"/>
<result property="CustomerServicePhone" column="CustomerServicePhone"/>
<result property="RevolvingLoanPhone" column="RevolvingLoanPhone"/>
<result property="EarlyRepayPhone" column="EarlyRepayPhone"/>
<result property="Email" column="Email"/>
<result property="SignAddress" column="SignAddress"/>
<result property="SignZipCode" column="SignZipCode"/>
<result property="IsDeleted" column="IsDeleted"/>
<result property="SignCity" column="SignCity"/>
<result property="IsEnable" column="IsEnable"/>
<result property="LastOperateId" column="LastOperateId"/>
<result property="LastUpdateTime" column="LastUpdateTime"/>
<result property="CreateTime" column="CreateTime"/>
<result property="OperateId" column="OperateId"/>
<result property="IsReceiveEmail" column="IsReceiveEmail"/>
</resultMap> <!--门店树 返回值 -->
<resultMap id="selectMap_T_DepartmentInfoTree" class="DepartmentInfoModel">
<result property="DepId" column="DepId"/>
<result property="SignZipCode" column="SignZipCode"/>
<result property="IsDeleted" column="IsDeleted"/>
<result property="SignCity" column="SignCity"/>
<result property="IsEnable" column="IsEnable"/>
<result property="LastOperateId" column="LastOperateId"/>
<result property="LastUpdateTime" column="LastUpdateTime"/>
<result property="CreateTime" column="CreateTime"/>
<result property="OperateId" column="OperateId"/>
<result property="DepName" column="DepName"/>
<result property="ParentDepId" column="ParentDepId"/>
<result property="DepCode" column="DepCode"/>
<result property="CustomerServicePhone" column="CustomerServicePhone"/>
<result property="RevolvingLoanPhone" column="RevolvingLoanPhone"/>
<result property="EarlyRepayPhone" column="EarlyRepayPhone"/>
<result property="Email" column="Email"/>
<result property="SignAddress" column="SignAddress"/> <result property="ParentName" column="ParentName"/>
<result property="sort" column="sort"/>
<result property="level" column="level"/>
<result property="IsReceiveEmail" column="IsReceiveEmail"/>
</resultMap>
</resultMaps> <statements>
<!-- 查询 需要后动修改分页时的排序字段 -->
<select id="select_T_DepartmentInfo" resultMap="selectMap_T_DepartmentInfo" resultClass="DepartmentInfoModel" parameterClass="DepartmentInfoModel">
SELECT
<isNotNull property="TopNums">
<![CDATA[ top $TopNums$]]>
</isNotNull>
MAX(row_n) over(partition by ) as TotalItems, *
FROM
(
<!-- ********* 必须要修改 order by a.Id ********* -->
SELECT ROW_NUMBER() OVER ( PARTITION BY ORDER BY a.DepId) AS row_n,a.DepId,a.DepName,a.ParentDepId,a.DepCode,a.CustomerServicePhone,a.RevolvingLoanPhone,a.EarlyRepayPhone,a.Email,a.SignAddress,a.SignZipCode,a.IsDeleted,a.SignCity,a.IsEnable,a.LastOperateId,a.LastUpdateTime,a.CreateTime,a.OperateId,a.IsReceiveEmail
FROM T_DepartmentInfo as a
<dynamic prepend="where"> <isNotNull prepend="and" property="DepId">
<![CDATA[ a.DepId=#DepId# ]]>
</isNotNull> <isNotNull prepend="and" property="IsReceiveEmail">
<![CDATA[ a.IsReceiveEmail=#IsReceiveEmail# ]]>
</isNotNull> <isNotNull prepend="and" property="DepName">
<![CDATA[ a.DepName=#DepName# ]]>
</isNotNull> <isNotNull prepend="and" property="ParentDepId">
<![CDATA[ a.ParentDepId=#ParentDepId# ]]>
</isNotNull> <isNotNull prepend="and" property="DepCode">
<![CDATA[ a.DepCode=#DepCode# ]]>
</isNotNull> <isNotNull prepend="and" property="CustomerServicePhone">
<![CDATA[ a.CustomerServicePhone=#CustomerServicePhone# ]]>
</isNotNull> <isNotNull prepend="and" property="RevolvingLoanPhone">
<![CDATA[ a.RevolvingLoanPhone=#RevolvingLoanPhone# ]]>
</isNotNull> <isNotNull prepend="and" property="EarlyRepayPhone">
<![CDATA[ a.EarlyRepayPhone=#EarlyRepayPhone# ]]>
</isNotNull> <isNotNull prepend="and" property="Email">
<![CDATA[ a.Email=#Email# ]]>
</isNotNull> <isNotNull prepend="and" property="SignAddress">
<![CDATA[ a.SignAddress=#SignAddress# ]]>
</isNotNull> <isNotNull prepend="and" property="SignZipCode">
<![CDATA[ a.SignZipCode=#SignZipCode# ]]>
</isNotNull> <isNotNull prepend="and" property="IsDeleted">
<![CDATA[ a.IsDeleted=#IsDeleted# ]]>
</isNotNull> <isNotNull prepend="and" property="SignCity">
<![CDATA[ a.SignCity=#SignCity# ]]>
</isNotNull> <isNotNull prepend="and" property="IsEnable">
<![CDATA[ a.IsEnable=#IsEnable# ]]>
</isNotNull> <isNotNull prepend="and" property="LastOperateId">
<![CDATA[ a.LastOperateId=#LastOperateId# ]]>
</isNotNull> <isNotNull prepend="and" property="LastUpdateTime_B">
<![CDATA[ a.LastUpdateTime>=#LastUpdateTime_B# ]]>
</isNotNull>
<isNotNull prepend="and" property="LastUpdateTime_E">
<![CDATA[ a.LastUpdateTime<=#LastUpdateTime_E# ]]>
</isNotNull> <isNotNull prepend="and" property="CreateTime_B">
<![CDATA[ a.CreateTime>=#CreateTime_B# ]]>
</isNotNull>
<isNotNull prepend="and" property="CreateTime_E">
<![CDATA[ a.CreateTime<=#CreateTime_E# ]]>
</isNotNull> <isNotNull prepend="and" property="OperateId">
<![CDATA[ a.OperateId=#OperateId# ]]>
</isNotNull> <!-- 一个例子 -->
<!--<isNotEmpty prepend="and" property="属性名">
字段名 like #属性名#
</isNotEmpty>-->
</dynamic>
) as a
<dynamic prepend="where">
<isNotNull property="PrevPageNums">
<![CDATA[ a.row_n>$PrevPageNums$]]>
</isNotNull>
</dynamic> </select> <!-- 数据分析 树-->
<procedure id="select_T_DepartmentInfoTree" parameterMap="selectMap_Dept_DeptInfo" resultMap="selectMap_T_DepartmentInfoTree" >
Proc_LoanStorDept
</procedure> <!-- 添加 -->
<insert id="insert_T_DepartmentInfo" parameterClass="DepartmentInfoModel">
<selectKey property="DepId" type="post" resultClass="int">
${selectKey}
</selectKey>
INSERT INTO T_DepartmentInfo
(
DepName,ParentDepId,DepCode,CustomerServicePhone,RevolvingLoanPhone,EarlyRepayPhone,Email,SignAddress,SignZipCode,IsDeleted,SignCity,IsEnable,LastOperateId,LastUpdateTime,CreateTime,OperateId,IsReceiveEmail
) VALUES
(
#DepName#,#ParentDepId#,#DepCode#,#CustomerServicePhone#,#RevolvingLoanPhone#,#EarlyRepayPhone#,#Email#,#SignAddress#,#SignZipCode#,#IsDeleted#,#SignCity#,#IsEnable#,#LastOperateId#,#LastUpdateTime#,#CreateTime#,#OperateId#,#IsReceiveEmail#
) </insert> <!-- 更新 -->
<update id="update_T_DepartmentInfo" parameterClass="DepartmentInfoModel">
UPDATE T_DepartmentInfo SET DepName=#DepName#,
ParentDepId=#ParentDepId#,
DepCode=#DepCode#,
CustomerServicePhone=#CustomerServicePhone#,
RevolvingLoanPhone=#RevolvingLoanPhone#,
EarlyRepayPhone=#EarlyRepayPhone#,
Email=#Email#,
SignAddress=#SignAddress#,
SignZipCode=#SignZipCode#,
IsDeleted=#IsDeleted#,
SignCity=#SignCity#,
IsEnable=#IsEnable#,
LastOperateId=#LastOperateId#,
LastUpdateTime=#LastUpdateTime#,
CreateTime=#CreateTime#,
OperateId=#OperateId#,
IsReceiveEmail=#IsReceiveEmail#
<!-- -->
WHERE T_DepartmentInfo.DepId=#DepId#
</update> <!--删除-->
<delete id="delete_T_DepartmentInfo" parameterClass="DepartmentInfoModel">
DELETE FROM T_DepartmentInfo where DepId=#DepId#
</delete> <!-- 删除-->
<delete id="delete_flag_T_DepartmentInfo" parameterClass="DepartmentInfoModel">
UPDATE T_DepartmentInfo set IsDeleted = where DepId=#DepId#
</delete>
</statements>
</sqlMap>
ibatis 存储过程写法的更多相关文章
- SQL组合查询的存储过程写法
最进一个项目 里面有个查询的功能,它是进行组合查询的, 而且用的是存储过程写.写这样的存储过程,需要注意单引号的使用,请看本人下面的例子,假如你以后写的话 记得注意写就行: create proc s ...
- mysql数据库-定义函数-存储过程写法
------------- mysql 定义自定义函数写法 DELIMITER $$ USE `iwmsdb`$$ DROP FUNCTION IF EXISTS `F_WM_DBNAME`$$ C ...
- oracle ibatis 存储过程 返回游标 嵌套表
自己解决问题了 问题总结: 1.index by表不能存储在数据库中的type中,故选择嵌套表. 2.ibatis不支持oracle的复合数据类型的返回.(个人理解) 3.替代方案:用返回oracle ...
- SQL Server分页的存储过程写法以及性能比较
------创建数据库data_Test ----- create database data_Test GO use data_Test GO create table tb_TestTable - ...
- iBATIS存储过程
使用iBATIS配置来调用存储过程.为了理解这一章,首先需要了解我们是如何在MySQL中创建一个存储过程. 在继续对本章学习之前,可以通过MySQL存储过程. 我们已经在MySQL下有EMPLOYEE ...
- Oracle存储过程写法
create or replace procedure QIANFEIGL_JIAOKUANDY( cebenh varchar2, kehuh varchar2, hetongh varchar2, ...
- mysql存储过程写法—动态参数运用
--删除 双击代码全选 1 drop procedure if exists up_common_select --创建 双击代码全选 1 2 3 4 5 6 7 8 9 10 11 12 13 14 ...
- Oracle常用存储过程写法
写在前面 这段时间工作最长接触到的就是Oracle数据库,不论查数据,还是统计.运行job,都离不开PL/SQL 存储过程,下面就整理下经常用到的知识. 一.Function函数 函数是执行非查询语句 ...
- 【Oracle】存储过程写法小例子
1.存储过程的基本语法: CREATE OR REPLACE PROCEDURE 存储过程名(param1 in type,param2 out type) IS 变量1 类型(值范围); 变量2 类 ...
随机推荐
- DBA_Oracle冷备份和热备份的处理(概念)
2014-07-27 Created By BaoXinjian
- HDU 1213 How Many Tables(并查集,简单)
题解:1 2,2 3,4 5,是朋友,所以可以坐一起,求最小的桌子数,那就是2个,因为1 2 3坐一桌,4 5坐一桌.简单的并查集应用,但注意题意是从1到n的,所以要减1. 代码: #include ...
- DPI和像素
像素(Pixel) 对于计算机的屏幕设备而言,像素(Pixel)或者说px是一个最基本的单位,就是一个点.其它所有的单位,都和像素成一个固定的比例换算关系.所有的长度单位基于屏幕进行显示的时候,都统一 ...
- 使用LKDBHelper 插入相同id时候应该是更新数据而不是插入新的数据
要实现使用LKDBHelp 插入相同id时候应该是更新数据而不是插入新的数据 例如#import "JSONModel.h" @interface InfoModel : JSON ...
- restful api设计中的幂等性的理解。
以前就听说过这个词,但是最近看了一些文章,产生了一些疑惑, GET是幂等性.例如查一条数据,如果你给定一个id.那么你查多少次.都是这条数据,但是我疑问,这里的幂等性指的是,每次都返回一条.这个数量, ...
- dual
1. dual 确实是一张表.是一张只有一个字段,一行记录的表. 2.习惯上,我们称之为'伪表'.因为他不存储主题数据.3. 他的存在,是为了操作上的方便.因为select 都是要有特定对象的.如:s ...
- C++学习26 运算符重载的概念和语法
所谓重载,就是赋予新的含义.函数重载(Function Overloading)可以让一个函数名有多种功能,在不同情况下进行不同的操作.运算符重载(Operator Overloading)也是一个道 ...
- [Java] 内部类的用法
package test.file; import java.io.File; import java.io.FilenameFilter; /** * 内部类的使用 * @author Frost. ...
- [HackerCup Round1 2] Autocomplete (Trie)
题目链接:https://www.facebook.com/hackercup/problems.php?pid=313229895540583&round=344496159068801 题 ...
- cwRsync 配置文件详解
GLOBAL PARAMETERS(全局参数) The first parameters in the file (before a [module] header) are the global p ...