1

我正在使用 ServiceStack ORMLite 来尝试更新我的数据库中的记录。我所有的 POCO 都实现了一个 IHasID 接口

public interface IHasId
{
    int Id { get; set; }
}

在我的 POCO 中,我有以下属性

private int id;

[ServiceStack.DataAnnotations.Alias("TableName_ID")]
    public int Id
    {
        get { return id; }
        set
        {
            if (value != this.id)
            {
                this.id = value;                    
                NotifyPropertyChanged("Id");
            }
        }
    }

我的每个存储库类都继承自具有以下方法的 DataRepositoryBase<T> 类:

public virtual T Update(T entity)
    {
        using (IDbConnection db = CreateDbConnection())
        {
            db.Update<T>(entity, e => e.Id == entity.Id);
            return entity;
        }
    }

当我在子存储库上调用此方法时,出现以下错误:

System.Data.SqlClient.SqlException (0x80131904):无法更新标识列“TableName_ID”。

我该如何解决这个错误?

我究竟做错了什么?

谢谢!

杰里米

4

2 回答 2

3

您还应该用 标记身份列[AutoIncrement],例如:

[AutoIncrement]
[Alias("TableName_ID")]
public int Id { ... ]
于 2013-10-09T16:37:59.813 回答
0

您通常不会更新身份字段,因为它们是由数据库自动生成的。在某些特定情况下,您可能希望更新标识字段,但您需要使用 SQL 执行此操作,因为它要求您在每个查询的开头和结尾使用 SET 语句。

于 2013-10-09T16:39:53.393 回答