关于iBatis.Net一对多查询问题和byte[]数据的处理问题

公司开发用到了iBatis.Net,关于一对多上面的问题还有一些image的处理,查了很多百度,测试了很久!
推荐这个博主,写的真不错,简单易懂 http://www.cnblogs.com/13590/archive/2013/03/01/2938126.html
和http://www.cnblogs.com/13590/archive/2013/03/14/2958735.html
我这简单的介绍一下关于一对多的配置
大概就这样配置

 <resultMaps>

    <resultMap id="MenuInfoMap" class="Model.Sys.MenuInfo">
      <result property="MenuGroupCode" column="MenuGroupCode" typeHandler="NullValueTypeHandlerCallback"/>
      <result property="MenuCode" column="MenuCode" typeHandler="NullValueTypeHandlerCallback"/>
      <result property="MenuName" column="MenuName" typeHandler="NullValueTypeHandlerCallback"/>
      <result property="MenuIco" column="MenuIco"/>
      <result property="MenuPath" column="MenuPath" typeHandler="NullValueTypeHandlerCallback"/>
      <result property="MenuFrmName" column="MenuFrmName" typeHandler="NullValueTypeHandlerCallback"/>
    </resultMap>
    
    <resultMap id="MenuGroupInfoMap" class="Model.Sys.MenuGroupInfo"  groupBy="MenuGroupCode">
      <result property="MenuGroupCode" column="MenuGroupCode" typeHandler="NullValueTypeHandlerCallback"/>
      <result property="MenuGroupName" column="MenuGroupName" typeHandler="NullValueTypeHandlerCallback"/>
      <result property="MenuInfoes" column="MenuInfoMap" resultMapping="NSMenuInfo.MenuInfoMap" />
    </resultMap>
  </resultMaps>
<!--这个groupby一定要加上
resultMapping的值指明MenuInfoes属性由结果映射集MenuInfoMap所表示的复杂数据类型表示。因为菜单组和子菜单是一对多的关系,在主表的结果映射上加入groupBy="MenuGroupCode"属性。
 -->

这个是查询的配置,首先你要在多的那一个类中定义一下,一定要加上序列化
在这里插入图片描述

<!--加载全部菜单-->
    <select id="LoadAllMenuGroup" parameterClass="System.Collections.IDictionary"  resultMap="MenuGroupInfoMap" >
      <![CDATA[
      select tbMenuGroup.MenuGroupName, tbMenuInfo.* from tbMenuGroup left join tbMenuInfo on tbMenuGroup.MenuGroupCode=tbMenuInfo.MenuGroupCode
      ]]>
    </select>


关于插入byte[]类型的数据,用的是sqlserver数据库,所以数据库类型定为了image
以下代码MenuIco这个字段在c#定义为了byte[],我开始直接处理,ibatis把他当成一个对象,或者一个字符串进行处理,
就是这样式的,

insert into tbMenuInfo(MenuGroupCode,MenuCode,MenuName,MenuIco,MenuPath,MenuFrmName)        values('0006','0001','运行',System.Byte[],'xxx','主窗体')

以下才是正确的处理方式
在这里插入图片描述

这个是配置方法:

<!--插入菜单-->
    <statement id="InsertMenu" parameterClass="System.Collections.IDictionary"  >
      <![CDATA[
      insert into tbMenuInfo(MenuGroupCode,MenuCode,MenuName,MenuIco,MenuPath,MenuFrmName)
      values(#MenuGroupCode#,#MenuCode#,#MenuName#,#MenuIco:Image#,#MenuPath#,#MenuFrmName#)
     ]]>
    </statement>

初学者参考参考

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值