gpt4 book ai didi

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

转载 作者:太空宇宙 更新时间:2023-11-03 22:14:29 26 4
gpt4 key购买 nike

我需要 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/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com