IBatisNet:让insert操作重返新增记录的主键值

类型引用ibatis包:

IBatisNet.Common.dll –文件版本1.6.2.0
IBatisNet.DataAccess.dll
IBatisNet.DataMapper.dll

 

连串目录结构:

图片 1

 

花色中央银行使ibatis做多少访问层已经有好长期了。开发小组成员反映ibatis的insert操作重回的结果是null,那点极度不爽。
其实,我们都以期望能够把新增记录的主键值再次回到出来。
上前一周,大家有反编写翻译ibatis的包,查看其促成原理,后来,又尝试任何方法,都没能给落实这一个效应。

那两天,决定找点时间,来消除这几个胸闷的事宜。

整合网上搜到的东东,计算出方案是透过insert语句的selectKey子成分来回到insert命令生成的记录的主键值。

一般来说是xml映射文件里insert节点:

<insert id="InsertEntity"  parameterclass="T_Ent_Project">
  insert into  T_Ent_Project(EntId,ProjectNo,ProjectName,BudgetAmount,LockedAmount,UsedAmount,AvailableAmount,Active,CreatedBy,CreatedTime,ModifiedBy,ModifidTime )
  values(  #EntId#, #ProjectNo#, #ProjectName#, #BudgetAmount#, #LockedAmount#, #UsedAmount#, #AvailableAmount#, #Active#, #CreatedBy#, #CreatedTime#, #ModifiedBy#, #ModifidTime# )

  <!--通过insert语句的selectKey子元素来返回insert命令生成的记录的主键值-->
  <selectKey resultClass="int" type="post" property="ProjectId">
    select @@IDENTITY
  </selectKey>
</insert>

急需注意的是,上边的select @@IDENTITY是相对于MsSql来讲的,假设数据库是mysql或oracle,会有差异。

除此以外,当selectKey配置失当,运营程序晤面世类似如下万分:

  • Unknown selectKey type : ”
  • There is no Set member named ” in class ‘T_Ent_Project’

 

正如是对ibatis做的crud的测试类:

using IBatisDemo.Domains;
using IBatisNet.DataMapper;
using IBatisNet.DataMapper.Configuration;
using Microsoft.VisualStudio.TestTools.UnitTesting;
using System;

namespace IBatisDemo
{
    [TestClass]
    public class IbatisCRUDTest
    {
        [TestMethod]
        public void TestCRUD()
        {
            // 初始化sqlmapper对象
            DomSqlMapBuilder builder = new DomSqlMapBuilder();//bin\\
            string path = System.AppDomain.CurrentDomain.BaseDirectory + /*"bin\\" +*/   "\\SqlMap.config";
            ISqlMapper mapper = builder.Configure(path);

            // 定义实体对象
            T_Ent_Project model = new T_Ent_Project()
            {
                ProjectName = "test mybatis",
                EntId = 0,
                CreatedTime = DateTime.Now
            };

            // insert 
            var ret = mapper.Insert("MyBatis_T_Ent_Project.InsertEntity", model);
            int newId = Convert.ToInt32(ret);
            Console.WriteLine("insert后的记录的主键值:" + newId);

            // select 
            var newModel = mapper.QueryForObject<T_Ent_Project>("MyBatis_T_Ent_Project.getByKey", newId);
            Assert.AreEqual(newId, newModel.ProjectId);

            //Update 和 Delete 都返回受影响的行数。
            model.ProjectId = newId;
            model.ProjectName += "updated";
            int updRowCount = mapper.Update("MyBatis_T_Ent_Project.UpdateEntity", model);
            Console.WriteLine("update影响行数:" + updRowCount);

            int delRet = mapper.Delete("MyBatis_T_Ent_Project.DeleteEntity", model.ProjectId);
            Console.WriteLine("delete影响行数:" + delRet);
        }
    }
}

测试重回结果:

图片 2