首页 > 解决方案 > 为什么服务堆栈返回 Int64 而不是 Int32?

问题描述

我的模型 SecPermission 的列 Id = int 是 Int32。当我添加新记录时,为什么它将新添加的 ID 返回为 Int64?

服务方式

public object Post(AddPermission request)
        {
            var perm = request.ConvertTo<SecPermission>();
            perm.AuditUserId = UserAuth.Id;
            LogInfo(typeof(SecPermission), request, LogAction.Insert);
            return Db.Insert(perm);
        }

单元测试代码

     using (var service = HostContext.ResolveService<SecurityService>(authenticatedRequest))
                    {
///**this line is returning an object with Int64 in it.
                        int id = (int) service.Post(new AddPermission { Name = name, Description = "TestDesc" });
                        service.Put(new UpdatePermission { Id = permission, Name = name,Description = "TestDesc" });
                        service.Delete(new DeletePermission { Id = Convert.ToInt32(id)});
                    }

     public class SecPermission : IAudit
            {
                [AutoIncrement]
                [PrimaryKey]
                public int Id { get; set; }

            [Required]
            [StringLength(50)]
            public string Name { get; set; }

            [Required]
            [StringLength(75)]
            public string Description { get; set; }

            [Required]
            public PermissionType PermissionType { get; set; }

            public int AuditUserId { get; set; }
            public DateTime AuditDate { get; set; } = DateTime.Now;
        }

标签: servicestack

解决方案


您永远不应该在 ServiceStack 服务中返回值类型,它需要是引用类型,通常是类型化响应 DTO,但也可以是原始数据类型,string或者byte[]但它不应该是像整数这样的值类型,它将失败在一些 ServiceStack 功能中工作。

对于这个服务,我要么返回SecPermission对象,要么返回AddPermissionResponse结果值中带有整数的对象。

请注意,OrmLite Insert()API 返回 along这就是您看到 long 的原因,但是您需要调用 Save() 或指定 selectIdentity:true以获取新插入的[AutoIncrement]主键 id,例如:

var newId = db.Insert(perm, selectIdentity:true);

或者

Db.Save(perm);
var newId = perm.Id; //auto populated with auto incremented primary key

此外,您不需要在 OrmLite 中同时[PrimaryKey]指定主键,就像使用Id 属性约定一样。[AutoIncrement][AutoIncrement]

此外,如果您要直接调用服务,您也可以键入响应以避免强制转换,例如:

public SecPermission Post(AddPermission request)
{
    //...
    Db.Save(perm);
    return perm;
}

那么直接调用就不需要强制转换了,例如:

var id = service.Post(new AddPermission { ... }).Id;

objectServiceStack 在使用或键入响应方面没有行为差异,SecPermission尽管最好使用IReturn<T>接口标记在您的请求 DTO 上指定它,例如:

public AddPermission : IReturn<SecPermission> { ... }

因为它在从服务客户端调用时启用端到端类型化 API,例如:

SecPermission response = client.Post(new AddPermission { ... });

推荐阅读