c# - 如何在 dbml 中标记为可序列化?

标签 c# linq-to-sql serialization

我需要 Linq & Serializable,所以我使用自动生成 dbml 并添加 Seriable。我只需要可序列化的“DVD 表”,但是有 <

尝试了很多组合,仍然因为错误而失败:

Type 'System.Data.Linq.EntityRef`1[[CategoryList, App_Code.dpv5xabw, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null]]' in Assembly 'System.Data.Linq, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089' is not marked as serializable.

[global::System.Data.Linq.Mapping.TableAttribute(Name="dbo.DvdList"),Serializable]
public partial class DvdList : INotifyPropertyChanging, INotifyPropertyChanged
{

private static PropertyChangingEventArgs emptyChangingEventArgs = new PropertyChangingEventArgs(String.Empty);

private int _DvdId;

private string _Title;

private int _CategoryId;

private EntityRef<CategoryList> _CategoryList;

#region Extensibility Method Definitions
partial void OnLoaded();
partial void OnValidate(System.Data.Linq.ChangeAction action);
partial void OnCreated();
partial void OnDvdIdChanging(int value);
partial void OnDvdIdChanged();
partial void OnTitleChanging(string value);
partial void OnTitleChanged();
partial void OnCategoryIdChanging(int value);
partial void OnCategoryIdChanged();
#endregion

public DvdList()
{
    this._CategoryList = default(EntityRef<CategoryList>);
    OnCreated();
}

[global::System.Data.Linq.Mapping.ColumnAttribute(Storage="_DvdId", AutoSync=AutoSync.OnInsert, DbType="Int NOT NULL IDENTITY", IsPrimaryKey=true, IsDbGenerated=true)]
public int DvdId
{
    get
    {
        return this._DvdId;
    }
    set
    {
        if ((this._DvdId != value))
        {
            this.OnDvdIdChanging(value);
            this.SendPropertyChanging();
            this._DvdId = value;
            this.SendPropertyChanged("DvdId");
            this.OnDvdIdChanged();
        }
    }
}

[global::System.Data.Linq.Mapping.ColumnAttribute(Storage="_Title", DbType="VarChar(50) NOT NULL", CanBeNull=false)]
public string Title
{
    get
    {
        return this._Title;
    }
    set
    {
        if ((this._Title != value))
        {
            this.OnTitleChanging(value);
            this.SendPropertyChanging();
            this._Title = value;
            this.SendPropertyChanged("Title");
            this.OnTitleChanged();
        }
    }
}

    [global::System.Data.Linq.Mapping.ColumnAttribute(Storage="_CategoryId", DbType="Int NOT NULL")]
public int CategoryId
{
    get
    {
        return this._CategoryId;
    }
    set
    {
        if ((this._CategoryId != value))
        {
            if (this._CategoryList.HasLoadedOrAssignedValue)
            {
                throw new System.Data.Linq.ForeignKeyReferenceAlreadyHasValueException();
            }
            this.OnCategoryIdChanging(value);
            this.SendPropertyChanging();
            this._CategoryId = value;
            this.SendPropertyChanged("CategoryId");
            this.OnCategoryIdChanged();
        }
    }
}

[global::System.Data.Linq.Mapping.AssociationAttribute(Name="CategoryList_DvdList", Storage="_CategoryList", ThisKey="CategoryId", OtherKey="CategoryId", IsForeignKey=true, DeleteOnNull=true, DeleteRule="CASCADE")]
public CategoryList CategoryList
{
    get
    {
        return this._CategoryList.Entity;
    }
    set
    {
        CategoryList previousValue = this._CategoryList.Entity;
        if (((previousValue != value) 
                    || (this._CategoryList.HasLoadedOrAssignedValue == false)))
        {
            this.SendPropertyChanging();
            if ((previousValue != null))
            {
                this._CategoryList.Entity = null;
                previousValue.DvdLists.Remove(this);
            }
            this._CategoryList.Entity = value;
            if ((value != null))
            {
                value.DvdLists.Add(this);
                this._CategoryId = value.CategoryId;
            }
            else
            {
                this._CategoryId = default(int);
            }
            this.SendPropertyChanged("CategoryList");
        }
    }
}

public event PropertyChangingEventHandler PropertyChanging;

public event PropertyChangedEventHandler PropertyChanged;

protected virtual void SendPropertyChanging()
{
    if ((this.PropertyChanging != null))
    {
        this.PropertyChanging(this, emptyChangingEventArgs);
    }
}

protected virtual void SendPropertyChanged(String propertyName)
{
    if ((this.PropertyChanged != null))
    {
        this.PropertyChanged(this, new PropertyChangedEventArgs(propertyName));
    }
}

最佳答案

您可以在分部类中定义它。

创建另一个 .cs 文件,然后使用:

[Serializable]
public partial class DvdList
{

}

关于c# - 如何在 dbml 中标记为可序列化?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5533370/

相关文章:

c# - 如何使用任何脚本判断给定的 URL 是否会重定向?

c# - 将抽象工厂与 StructureMap 一起使用的可能性

c# - 使用 Linq-to-Sql 表达式生成 SQL 子句

c# - 在一个程序集中序列化,在另一个程序集中反序列化?

c# - 如何使用许多其他 if 条件循环 if 语句

c# - MySqlClient.NativeDriver 中的 NullReferenceException

c# - bool 值求值的 LINQ to SQL 顺序

c# - 使用泛型的 LINQ 连接

python - Python 文字的安全读取

rest - Jackson( Jersey )反序列化异常 - (对于 id 类型 'Id.class' ): no such class found