1062 lines
36 KiB
C#
1062 lines
36 KiB
C#
using System;
|
|
using System.Collections.Generic;
|
|
using System.Linq;
|
|
using Kreta.DataAccess.Interfaces;
|
|
using Kreta.Framework;
|
|
using Kreta.Framework.Actions;
|
|
using Kreta.Framework.Collections;
|
|
using Kreta.Framework.Collections.Generic;
|
|
using Kreta.Framework.Entities;
|
|
using Kreta.Framework.Entities.Generic;
|
|
using Kreta.Framework.Exceptions;
|
|
|
|
namespace SDA.Kreta.Entities
|
|
{
|
|
/// <summary>
|
|
/// Az UML modell OsszefuggoSzakGyak entitásának megvalósítása.
|
|
/// </summary>
|
|
/// <remarks>A kód teljes egészében generált, kézi módosítása nem megengedett!</remarks>
|
|
[Entity("OsszefuggoSzakGyak")]
|
|
// alapértelmezett EntityHistoryMode
|
|
public class OsszefuggoSzakGyak : Entity, IOsszefuggoSzakGyak
|
|
{
|
|
internal protected OsszefuggoSzakGyak()
|
|
: base()
|
|
{
|
|
}
|
|
|
|
public class AttributeInfo
|
|
{
|
|
public const string Megjegyzes = "Megjegyzes";
|
|
public const string Teljesitett = "Teljesitett";
|
|
public const string TeljesitesDatum = "TeljesitesDatum";
|
|
}
|
|
|
|
public class AttributeLengthInfo
|
|
{
|
|
public const int MegjegyzesLength = 2147483647;
|
|
}
|
|
|
|
#region General
|
|
private OsszefuggoSzakGyakDA m_DA = new OsszefuggoSzakGyakDA();
|
|
|
|
protected static OsszefuggoSzakGyak FakeOsszefuggoSzakGyak { get; set; }
|
|
|
|
public static OsszefuggoSzakGyak GiveAnInstance()
|
|
{
|
|
OsszefuggoSzakGyak result = FakeOsszefuggoSzakGyak == null
|
|
? new OsszefuggoSzakGyak()
|
|
: (OsszefuggoSzakGyak)FakeOsszefuggoSzakGyak.MemberwiseClone();
|
|
result.Reset();
|
|
result.SetDefaultData();
|
|
|
|
return result;
|
|
}
|
|
|
|
protected void SetDefaultData()
|
|
{
|
|
if (UserContext.Instance != null)
|
|
{
|
|
if (UserContext.Instance.IntezmenyId > 0)
|
|
{
|
|
IntezmenyId = UserContext.Instance.IntezmenyId;
|
|
}
|
|
|
|
if (UserContext.Instance.AktivTanevId > 0)
|
|
{
|
|
TanevId = UserContext.Instance.AktivTanevId;
|
|
}
|
|
|
|
m_State = EntityState.Uninitialized;
|
|
}
|
|
}
|
|
|
|
protected override IEntityDataAccessor GetDataAccessor() { return m_DA; }
|
|
protected internal virtual IEntityDataAccessor InheritedDA { get { return null; } }
|
|
|
|
[Obsolete("Ezt ne használjátok, mert mindenhova bele kellene fogalmazni a tanév szűrést is! Meg fog majd szűnni!")]
|
|
public static IEntityCollection<OsszefuggoSzakGyak> LoadAll()
|
|
{
|
|
return LoadWithFilter("");
|
|
}
|
|
|
|
[Obsolete("Ezt ne használjátok, mert mindenhova bele kellene fogalmazni a tanév szűrést is! Meg fog majd szűnni!")]
|
|
public static IEntityCollection<OsszefuggoSzakGyak> LoadAll(ColumnFilterMode columnFilterMode, IEnumerable<string> columns)
|
|
{
|
|
return LoadWithFilter("", columnFilterMode, columns);
|
|
}
|
|
|
|
[Obsolete("Ezt ne használjátok, mert mindenhova bele kellene fogalmazni a tanév szűrést is! Meg fog majd szűnni!")]
|
|
public static IEntityCollection<OsszefuggoSzakGyak> LoadWithFilter(string filter, Dictionary<string, object> commandParameters = null)
|
|
{
|
|
var result = new EntityCollection<OsszefuggoSzakGyak>();
|
|
new OsszefuggoSzakGyakDA().LoadWithFilter(result, filter, commandParameters);
|
|
return result;
|
|
}
|
|
|
|
[Obsolete("Ezt ne használjátok, mert mindenhova bele kellene fogalmazni a tanév szűrést is! Meg fog majd szűnni!")]
|
|
public static IEntityCollection<OsszefuggoSzakGyak> LoadWithFilter(string filter, ColumnFilterMode columnFilterMode, IEnumerable<string> columns, Dictionary<string, object> commandParameters = null)
|
|
{
|
|
var result = new EntityCollection<OsszefuggoSzakGyak>();
|
|
new OsszefuggoSzakGyakDA().LoadWithFilter(result, filter, columnFilterMode, columns, commandParameters);
|
|
return result;
|
|
}
|
|
|
|
protected override void StoreOriginalValues()
|
|
{
|
|
base.StoreOriginalValues();
|
|
OriginalValues.Add("Megjegyzes", (Megjegyzes == null ? (object)DBNull.Value : (object)m_Megjegyzes));
|
|
OriginalValues.Add("Teljesitett", (Teljesitett == null ? (object)DBNull.Value : (object)m_Teljesitett));
|
|
OriginalValues.Add("TeljesitesDatum", (TeljesitesDatum == null ? (object)DBNull.Value : (object)m_TeljesitesDatum));
|
|
OriginalValues.Add("TantargyId", (m_TantargyId < 0 ? (object)DBNull.Value : (object)m_TantargyId));
|
|
OriginalValues.Add("TanuloId", (m_TanuloId < 0 ? (object)DBNull.Value : (object)m_TanuloId));
|
|
OriginalValues.Add("CsoportId", (m_CsoportId < 0 ? (object)DBNull.Value : (object)m_CsoportId));
|
|
OriginalValues.Add("IntezmenyId", (m_IntezmenyId < 0 ? (object)DBNull.Value : (object)m_IntezmenyId));
|
|
OriginalValues.Add("TanevId", (m_TanevId < 0 ? (object)DBNull.Value : (object)m_TanevId));
|
|
}
|
|
|
|
#endregion
|
|
|
|
|
|
#region Ellenőrzés
|
|
|
|
protected override void Validate(bool skipValidateAttributes = false)
|
|
{
|
|
base.Validate();
|
|
|
|
if (!skipValidateAttributes)
|
|
{
|
|
// korlátos hosszúságú mezők ellenőrzése...
|
|
if (m_Megjegyzes != null && m_Megjegyzes.Length > 2147483647)
|
|
{
|
|
throw new InvalidEntityAttributeException("OsszefuggoSzakGyak", "Megjegyzes", EntityAttributeError.TooLong);
|
|
}
|
|
}
|
|
|
|
// kötelező asszociációk ellenőrzése...
|
|
if (m_TantargyId == -1) { throw new InvalidEntityAttributeException("OsszefuggoSzakGyak", "TantargyId", EntityAttributeError.Empty); }
|
|
if (m_TanuloId == -1) { throw new InvalidEntityAttributeException("OsszefuggoSzakGyak", "TanuloId", EntityAttributeError.Empty); }
|
|
if (m_CsoportId == -1) { throw new InvalidEntityAttributeException("OsszefuggoSzakGyak", "CsoportId", EntityAttributeError.Empty); }
|
|
if (m_IntezmenyId == -1) { throw new InvalidEntityAttributeException("OsszefuggoSzakGyak", "IntezmenyId", EntityAttributeError.Empty); }
|
|
if (m_TanevId == -1) { throw new InvalidEntityAttributeException("OsszefuggoSzakGyak", "TanevId", EntityAttributeError.Empty); }
|
|
|
|
|
|
|
|
}
|
|
|
|
#endregion
|
|
|
|
#region Alaphelyzetbe állítás
|
|
protected override void Reset()
|
|
{
|
|
base.Reset();
|
|
|
|
// alaphelyzetbe állítjuk az egyszerű mezőket
|
|
this.m_Megjegyzes = null;
|
|
this.m_Teljesitett = null;
|
|
this.m_TeljesitesDatum = null;
|
|
|
|
// alaphelyzetbe állítjuk az asszociációkból származó mezőket
|
|
this.m_TantargyId = -1;
|
|
this.m_Tantargy = null; // Entity
|
|
this.m_TanuloId = -1;
|
|
this.m_Tanulo = null; // Entity
|
|
this.m_CsoportId = -1;
|
|
this.m_Csoport = null; // Entity
|
|
this.m_TanuloErtekeles = null; // EntityCollection
|
|
this.m_ErtekelesTantargyi = null; // EntityCollection
|
|
this.m_IntezmenyId = -1;
|
|
this.m_Intezmeny = null; // Entity
|
|
this.m_TanevId = -1;
|
|
this.m_Tanev = null; // Entity
|
|
}
|
|
|
|
#endregion
|
|
|
|
protected override void DeAssociateBeforeDelete(bool runHandler = false)
|
|
{
|
|
// Nem kaszkád törölhető asszociációk ellenőrzése, hogy üresek-e...
|
|
|
|
// Tantargy esetében mi mutatunk a másikra: startrole: 0..*, endrole: 1
|
|
// Tanulo esetében mi mutatunk a másikra: startrole: 0..*, endrole: 1
|
|
// Csoport esetében mi mutatunk a másikra: startrole: 0..*, endrole: 1
|
|
if (this.TanuloErtekeles.Count > 0)
|
|
{
|
|
throw new EntityDeleteFailedException("OsszefuggoSzakGyak", "TanuloErtekeles", EntityUtil.GetAssociationDescription("T_TANULOERTEKELES_OSSZES", "C_OSSZEFUGGOSZAKGYAKID")); // nincs kapcsolotabla
|
|
}
|
|
if (this.ErtekelesTantargyi.Count > 0)
|
|
{
|
|
throw new EntityDeleteFailedException("OsszefuggoSzakGyak", "ErtekelesTantargyi", EntityUtil.GetAssociationDescription("T_ERTEKELESTANTARGYI_OSSZES", "C_OSSZEFUGGOSZAKGYAKID")); // nincs kapcsolotabla
|
|
}
|
|
// Intezmeny esetében mi mutatunk a másikra: startrole: *, endrole: 1
|
|
// Tanev esetében mi mutatunk a másikra: startrole: *, endrole: 1
|
|
|
|
// kaszkád törlések...
|
|
|
|
}
|
|
|
|
#region Mezők és tulajdonságok
|
|
|
|
#region Egyszerű mezők
|
|
|
|
#region Megjegyzes
|
|
|
|
protected internal string m_Megjegyzes;
|
|
|
|
/// <summary>
|
|
/// Nincs definiálva megjegyzés.
|
|
/// </summary>
|
|
[EntityProperty("Megjegyzes", EntityPropertyBaseType.ValueType, typeof(string), EntityCopyMethod.ShallowCopy)]
|
|
public virtual string Megjegyzes
|
|
{
|
|
get
|
|
{
|
|
return m_Megjegyzes;
|
|
}
|
|
set
|
|
{
|
|
CheckModifyable();
|
|
|
|
if (m_Megjegyzes == value) return;
|
|
m_Megjegyzes = value;
|
|
FieldModified("Megjegyzes", value);
|
|
|
|
}
|
|
}
|
|
|
|
#endregion
|
|
|
|
#region Teljesitett
|
|
|
|
protected internal bool? m_Teljesitett;
|
|
|
|
/// <summary>
|
|
/// Nincs definiálva megjegyzés.
|
|
/// </summary>
|
|
[EntityProperty("Teljesitett", EntityPropertyBaseType.ValueType, typeof(bool), EntityCopyMethod.ShallowCopy)]
|
|
public virtual bool? Teljesitett
|
|
{
|
|
get
|
|
{
|
|
return m_Teljesitett;
|
|
}
|
|
set
|
|
{
|
|
CheckModifyable();
|
|
|
|
if (m_Teljesitett == value) return;
|
|
m_Teljesitett = value;
|
|
FieldModified("Teljesitett", value);
|
|
|
|
}
|
|
}
|
|
|
|
#endregion
|
|
|
|
#region TeljesitesDatum
|
|
|
|
protected internal DateTime? m_TeljesitesDatum;
|
|
|
|
/// <summary>
|
|
/// Nincs definiálva megjegyzés.
|
|
/// </summary>
|
|
[EntityProperty("TeljesitesDatum", EntityPropertyBaseType.ValueType, typeof(DateTime), EntityCopyMethod.ShallowCopy)]
|
|
public virtual DateTime? TeljesitesDatum
|
|
{
|
|
get
|
|
{
|
|
return m_TeljesitesDatum;
|
|
}
|
|
set
|
|
{
|
|
CheckModifyable();
|
|
|
|
if (m_TeljesitesDatum == value) return;
|
|
m_TeljesitesDatum = value;
|
|
FieldModified("TeljesitesDatum", value);
|
|
|
|
}
|
|
}
|
|
|
|
#endregion
|
|
|
|
#endregion
|
|
|
|
#region Asszociációkkal kapcsolatos dolgok
|
|
|
|
protected internal virtual bool LoadByTanuloErtekelesId(int id)
|
|
{
|
|
return m_DA.LoadByTanuloErtekelesId(id, this);
|
|
}
|
|
|
|
protected internal virtual bool LoadByErtekelesTantargyiId(int id)
|
|
{
|
|
return m_DA.LoadByErtekelesTantargyiId(id, this);
|
|
}
|
|
|
|
#region OsszefuggoSzakGyak (0..*) -> Tantargy (1)
|
|
|
|
protected internal int m_TantargyId = -1;
|
|
|
|
/// <summary>
|
|
/// A(z) Tantargy asszociáció végpontjának ID-ja.
|
|
/// </summary>
|
|
/// <remarks>
|
|
/// - Insert() előtt célszerű kitölteni
|
|
/// - Update() nincs rá hatással: ezt a mezőt nem frissíti
|
|
/// - LoadByID() felhozza ezt a mezőt
|
|
/// </remarks>
|
|
public virtual int TantargyId
|
|
{
|
|
get
|
|
{
|
|
return InternalTantargyId;
|
|
}
|
|
set
|
|
{
|
|
InternalTantargyId = value;
|
|
}
|
|
}
|
|
|
|
/// <summary>
|
|
/// Ez egy külön bejárat a DA számára
|
|
/// <summary>
|
|
internal int InternalTantargyId
|
|
{
|
|
get
|
|
{
|
|
if (m_Tantargy != null)
|
|
{
|
|
return m_Tantargy.ID;
|
|
}
|
|
else
|
|
{
|
|
return m_TantargyId;// XXX az meg nem teljesen OK
|
|
}
|
|
}
|
|
set
|
|
{
|
|
CheckModifyable();
|
|
if (m_TantargyId != value)
|
|
{
|
|
m_TantargyId = value;
|
|
m_Tantargy = null;
|
|
FieldModified("TantargyId", value);
|
|
}
|
|
}
|
|
}
|
|
|
|
/// <summary>
|
|
/// Ez egy külön bejárat a DA számára
|
|
/// <summary>
|
|
internal void ModifyTantargy(Tantargy value)
|
|
{
|
|
m_TantargyId = value != null ? value.ID : -1;
|
|
m_Tantargy = value;
|
|
FieldModified("TantargyId", value != null ? (object)value.ID : DBNull.Value);
|
|
}
|
|
|
|
protected internal void SetTantargy(Tantargy value)
|
|
{
|
|
m_Tantargy = value;
|
|
if (value != null)
|
|
{
|
|
m_TantargyId = value.ID;
|
|
}
|
|
else
|
|
{
|
|
m_TantargyId = -1;
|
|
}
|
|
}
|
|
|
|
protected Tantargy m_Tantargy = null;
|
|
|
|
ITantargy IOsszefuggoSzakGyak.Tantargy
|
|
{
|
|
get { return Tantargy; }
|
|
set { Tantargy = value as Tantargy; }
|
|
}
|
|
|
|
/// <summary>
|
|
/// Nincs definiálva megjegyzés.
|
|
/// </summary>
|
|
/// <remarks>
|
|
/// Az UML modellben szereplő OsszefuggoSzakGyak és Tantargy entitások közötti asszociáció megvalósítása.
|
|
/// </remarks>
|
|
[EntityProperty("Tantargy", EntityPropertyBaseType.Entity, typeof(Tantargy), EntityCopyMethod.ShallowCopy)]
|
|
public virtual Tantargy Tantargy
|
|
{
|
|
get
|
|
{
|
|
if ((m_Tantargy == null) && (m_TantargyId != -1))
|
|
{
|
|
SDA.Kreta.Entities.Tantargy partner = SDA.Kreta.Entities.Tantargy.GiveAnInstance();
|
|
partner.LoadByID(m_TantargyId);
|
|
|
|
this.SetTantargy(partner);
|
|
}
|
|
// természetesen null-t adunk vissza, ha nem tudtunk felhozni semmit
|
|
return m_Tantargy;
|
|
}
|
|
set
|
|
{
|
|
CheckModifyable();
|
|
if (value != null)
|
|
{
|
|
if ((m_Tantargy == null) || (value.ID != m_Tantargy.ID))
|
|
{
|
|
if (value.State != EntityState.Initialized)
|
|
{
|
|
throw new EntityStateException(value.State);
|
|
}
|
|
if ((this.State != EntityState.New))
|
|
{
|
|
// Lista van a másik oldalon, úgyhogy a lista DA-ját használjuk
|
|
SDA.Kreta.Entities.Tantargy_OsszefuggoSzakGyak_DA da = new Tantargy_OsszefuggoSzakGyak_DA(value);
|
|
da.AddItem(this);
|
|
this.SetTantargy(value);
|
|
}
|
|
else
|
|
{
|
|
this.SetTantargy(value);
|
|
}
|
|
FieldModified("TantargyId", value.ID);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
// ki kell törölni a kapcsolatot az adatbázisban
|
|
this.SetTantargy(null);
|
|
UpdateAssociations();
|
|
FieldModified("TantargyId", DBNull.Value);
|
|
}
|
|
}
|
|
}
|
|
#endregion
|
|
|
|
#region OsszefuggoSzakGyak (0..*) -> Tanulo (1)
|
|
|
|
protected internal int m_TanuloId = -1;
|
|
|
|
/// <summary>
|
|
/// A(z) Tanulo asszociáció végpontjának ID-ja.
|
|
/// </summary>
|
|
/// <remarks>
|
|
/// - Insert() előtt célszerű kitölteni
|
|
/// - Update() nincs rá hatással: ezt a mezőt nem frissíti
|
|
/// - LoadByID() felhozza ezt a mezőt
|
|
/// </remarks>
|
|
public virtual int TanuloId
|
|
{
|
|
get
|
|
{
|
|
return InternalTanuloId;
|
|
}
|
|
set
|
|
{
|
|
InternalTanuloId = value;
|
|
}
|
|
}
|
|
|
|
/// <summary>
|
|
/// Ez egy külön bejárat a DA számára
|
|
/// <summary>
|
|
internal int InternalTanuloId
|
|
{
|
|
get
|
|
{
|
|
if (m_Tanulo != null)
|
|
{
|
|
return m_Tanulo.ID;
|
|
}
|
|
else
|
|
{
|
|
return m_TanuloId;// XXX az meg nem teljesen OK
|
|
}
|
|
}
|
|
set
|
|
{
|
|
CheckModifyable();
|
|
if (m_TanuloId != value)
|
|
{
|
|
m_TanuloId = value;
|
|
m_Tanulo = null;
|
|
FieldModified("TanuloId", value);
|
|
}
|
|
}
|
|
}
|
|
|
|
/// <summary>
|
|
/// Ez egy külön bejárat a DA számára
|
|
/// <summary>
|
|
internal void ModifyTanulo(Tanulo value)
|
|
{
|
|
m_TanuloId = value != null ? value.ID : -1;
|
|
m_Tanulo = value;
|
|
FieldModified("TanuloId", value != null ? (object)value.ID : DBNull.Value);
|
|
}
|
|
|
|
protected internal void SetTanulo(Tanulo value)
|
|
{
|
|
m_Tanulo = value;
|
|
if (value != null)
|
|
{
|
|
m_TanuloId = value.ID;
|
|
}
|
|
else
|
|
{
|
|
m_TanuloId = -1;
|
|
}
|
|
}
|
|
|
|
protected Tanulo m_Tanulo = null;
|
|
|
|
ITanulo IOsszefuggoSzakGyak.Tanulo
|
|
{
|
|
get { return Tanulo; }
|
|
set { Tanulo = value as Tanulo; }
|
|
}
|
|
|
|
/// <summary>
|
|
/// Nincs definiálva megjegyzés.
|
|
/// </summary>
|
|
/// <remarks>
|
|
/// Az UML modellben szereplő OsszefuggoSzakGyak és Tanulo entitások közötti asszociáció megvalósítása.
|
|
/// </remarks>
|
|
[EntityProperty("Tanulo", EntityPropertyBaseType.Entity, typeof(Tanulo), EntityCopyMethod.ShallowCopy)]
|
|
public virtual Tanulo Tanulo
|
|
{
|
|
get
|
|
{
|
|
if ((m_Tanulo == null) && (m_TanuloId != -1))
|
|
{
|
|
SDA.Kreta.Entities.Tanulo partner = SDA.Kreta.Entities.Tanulo.GiveAnInstance();
|
|
partner.LoadByID(m_TanuloId);
|
|
|
|
this.SetTanulo(partner);
|
|
}
|
|
// természetesen null-t adunk vissza, ha nem tudtunk felhozni semmit
|
|
return m_Tanulo;
|
|
}
|
|
set
|
|
{
|
|
CheckModifyable();
|
|
if (value != null)
|
|
{
|
|
if ((m_Tanulo == null) || (value.ID != m_Tanulo.ID))
|
|
{
|
|
if (value.State != EntityState.Initialized)
|
|
{
|
|
throw new EntityStateException(value.State);
|
|
}
|
|
if ((this.State != EntityState.New))
|
|
{
|
|
// Lista van a másik oldalon, úgyhogy a lista DA-ját használjuk
|
|
SDA.Kreta.Entities.Tanulo_OsszefuggoSzakGyak_DA da = new Tanulo_OsszefuggoSzakGyak_DA(value);
|
|
da.AddItem(this);
|
|
this.SetTanulo(value);
|
|
}
|
|
else
|
|
{
|
|
this.SetTanulo(value);
|
|
}
|
|
FieldModified("TanuloId", value.ID);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
// ki kell törölni a kapcsolatot az adatbázisban
|
|
this.SetTanulo(null);
|
|
UpdateAssociations();
|
|
FieldModified("TanuloId", DBNull.Value);
|
|
}
|
|
}
|
|
}
|
|
#endregion
|
|
|
|
#region OsszefuggoSzakGyak (0..*) -> Csoport (1)
|
|
|
|
protected internal int m_CsoportId = -1;
|
|
|
|
/// <summary>
|
|
/// A(z) Csoport asszociáció végpontjának ID-ja.
|
|
/// </summary>
|
|
/// <remarks>
|
|
/// - Insert() előtt célszerű kitölteni
|
|
/// - Update() nincs rá hatással: ezt a mezőt nem frissíti
|
|
/// - LoadByID() felhozza ezt a mezőt
|
|
/// </remarks>
|
|
public virtual int CsoportId
|
|
{
|
|
get
|
|
{
|
|
return InternalCsoportId;
|
|
}
|
|
set
|
|
{
|
|
InternalCsoportId = value;
|
|
}
|
|
}
|
|
|
|
/// <summary>
|
|
/// Ez egy külön bejárat a DA számára
|
|
/// <summary>
|
|
internal int InternalCsoportId
|
|
{
|
|
get
|
|
{
|
|
if (m_Csoport != null)
|
|
{
|
|
return m_Csoport.ID;
|
|
}
|
|
else
|
|
{
|
|
return m_CsoportId;// XXX az meg nem teljesen OK
|
|
}
|
|
}
|
|
set
|
|
{
|
|
CheckModifyable();
|
|
if (m_CsoportId != value)
|
|
{
|
|
m_CsoportId = value;
|
|
m_Csoport = null;
|
|
FieldModified("CsoportId", value);
|
|
}
|
|
}
|
|
}
|
|
|
|
/// <summary>
|
|
/// Ez egy külön bejárat a DA számára
|
|
/// <summary>
|
|
internal void ModifyCsoport(Csoport value)
|
|
{
|
|
m_CsoportId = value != null ? value.ID : -1;
|
|
m_Csoport = value;
|
|
FieldModified("CsoportId", value != null ? (object)value.ID : DBNull.Value);
|
|
}
|
|
|
|
protected internal void SetCsoport(Csoport value)
|
|
{
|
|
m_Csoport = value;
|
|
if (value != null)
|
|
{
|
|
m_CsoportId = value.ID;
|
|
}
|
|
else
|
|
{
|
|
m_CsoportId = -1;
|
|
}
|
|
}
|
|
|
|
protected Csoport m_Csoport = null;
|
|
|
|
ICsoport IOsszefuggoSzakGyak.Csoport
|
|
{
|
|
get { return Csoport; }
|
|
set { Csoport = value as Csoport; }
|
|
}
|
|
|
|
/// <summary>
|
|
/// Nincs definiálva megjegyzés.
|
|
/// </summary>
|
|
/// <remarks>
|
|
/// Az UML modellben szereplő OsszefuggoSzakGyak és Csoport entitások közötti asszociáció megvalósítása.
|
|
/// </remarks>
|
|
[EntityProperty("Csoport", EntityPropertyBaseType.Entity, typeof(Csoport), EntityCopyMethod.ShallowCopy)]
|
|
public virtual Csoport Csoport
|
|
{
|
|
get
|
|
{
|
|
if ((m_Csoport == null) && (m_CsoportId != -1))
|
|
{
|
|
SDA.Kreta.Entities.Csoport partner = SDA.Kreta.Entities.Csoport.GiveAnInstance();
|
|
partner.LoadByID(m_CsoportId);
|
|
|
|
this.SetCsoport(partner);
|
|
}
|
|
// természetesen null-t adunk vissza, ha nem tudtunk felhozni semmit
|
|
return m_Csoport;
|
|
}
|
|
set
|
|
{
|
|
CheckModifyable();
|
|
if (value != null)
|
|
{
|
|
if ((m_Csoport == null) || (value.ID != m_Csoport.ID))
|
|
{
|
|
if (value.State != EntityState.Initialized)
|
|
{
|
|
throw new EntityStateException(value.State);
|
|
}
|
|
if ((this.State != EntityState.New))
|
|
{
|
|
// Lista van a másik oldalon, úgyhogy a lista DA-ját használjuk
|
|
SDA.Kreta.Entities.Csoport_OsszefuggoSzakGyak_DA da = new Csoport_OsszefuggoSzakGyak_DA(value);
|
|
da.AddItem(this);
|
|
this.SetCsoport(value);
|
|
}
|
|
else
|
|
{
|
|
this.SetCsoport(value);
|
|
}
|
|
FieldModified("CsoportId", value.ID);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
// ki kell törölni a kapcsolatot az adatbázisban
|
|
this.SetCsoport(null);
|
|
UpdateAssociations();
|
|
FieldModified("CsoportId", DBNull.Value);
|
|
}
|
|
}
|
|
}
|
|
#endregion
|
|
|
|
#region OsszefuggoSzakGyak (*) -> Intezmeny (1)
|
|
|
|
protected internal int m_IntezmenyId = -1;
|
|
|
|
/// <summary>
|
|
/// A(z) Intezmeny asszociáció végpontjának ID-ja.
|
|
/// </summary>
|
|
/// <remarks>
|
|
/// - Insert() előtt célszerű kitölteni
|
|
/// - Update() nincs rá hatással: ezt a mezőt nem frissíti
|
|
/// - LoadByID() felhozza ezt a mezőt
|
|
/// </remarks>
|
|
public virtual int IntezmenyId
|
|
{
|
|
get
|
|
{
|
|
return InternalIntezmenyId;
|
|
}
|
|
set
|
|
{
|
|
InternalIntezmenyId = value;
|
|
}
|
|
}
|
|
|
|
/// <summary>
|
|
/// Ez egy külön bejárat a DA számára
|
|
/// <summary>
|
|
internal int InternalIntezmenyId
|
|
{
|
|
get
|
|
{
|
|
if (m_Intezmeny != null)
|
|
{
|
|
return m_Intezmeny.ID;
|
|
}
|
|
else
|
|
{
|
|
return m_IntezmenyId;// XXX az meg nem teljesen OK
|
|
}
|
|
}
|
|
set
|
|
{
|
|
CheckModifyable();
|
|
if (m_IntezmenyId != value)
|
|
{
|
|
m_IntezmenyId = value;
|
|
m_Intezmeny = null;
|
|
FieldModified("IntezmenyId", value);
|
|
}
|
|
}
|
|
}
|
|
|
|
/// <summary>
|
|
/// Ez egy külön bejárat a DA számára
|
|
/// <summary>
|
|
internal void ModifyIntezmeny(Intezmeny value)
|
|
{
|
|
m_IntezmenyId = value != null ? value.ID : -1;
|
|
m_Intezmeny = value;
|
|
FieldModified("IntezmenyId", value != null ? (object)value.ID : DBNull.Value);
|
|
}
|
|
|
|
protected internal void SetIntezmeny(Intezmeny value)
|
|
{
|
|
m_Intezmeny = value;
|
|
if (value != null)
|
|
{
|
|
m_IntezmenyId = value.ID;
|
|
}
|
|
else
|
|
{
|
|
m_IntezmenyId = -1;
|
|
}
|
|
}
|
|
|
|
protected Intezmeny m_Intezmeny = null;
|
|
|
|
IIntezmeny IOsszefuggoSzakGyak.Intezmeny
|
|
{
|
|
get { return Intezmeny; }
|
|
set { Intezmeny = value as Intezmeny; }
|
|
}
|
|
|
|
/// <summary>
|
|
/// Nincs definiálva megjegyzés.
|
|
/// </summary>
|
|
/// <remarks>
|
|
/// Az UML modellben szereplő OsszefuggoSzakGyak és Intezmeny entitások közötti asszociáció megvalósítása.
|
|
/// </remarks>
|
|
[EntityProperty("Intezmeny", EntityPropertyBaseType.Entity, typeof(Intezmeny), EntityCopyMethod.ShallowCopy)]
|
|
public virtual Intezmeny Intezmeny
|
|
{
|
|
get
|
|
{
|
|
if ((m_Intezmeny == null) && (m_IntezmenyId != -1))
|
|
{
|
|
SDA.Kreta.Entities.Intezmeny partner = SDA.Kreta.Entities.Intezmeny.GiveAnInstance();
|
|
partner.LoadByID(m_IntezmenyId);
|
|
|
|
this.SetIntezmeny(partner);
|
|
}
|
|
// természetesen null-t adunk vissza, ha nem tudtunk felhozni semmit
|
|
return m_Intezmeny;
|
|
}
|
|
set
|
|
{
|
|
CheckModifyable();
|
|
if (value != null)
|
|
{
|
|
if ((m_Intezmeny == null) || (value.ID != m_Intezmeny.ID))
|
|
{
|
|
if (value.State != EntityState.Initialized)
|
|
{
|
|
throw new EntityStateException(value.State);
|
|
}
|
|
if ((this.State != EntityState.New))
|
|
{
|
|
// Lista van a másik oldalon, úgyhogy a lista DA-ját használjuk
|
|
SDA.Kreta.Entities.Intezmeny_OsszefuggoSzakGyak_DA da = new Intezmeny_OsszefuggoSzakGyak_DA(value);
|
|
da.AddItem(this);
|
|
this.SetIntezmeny(value);
|
|
}
|
|
else
|
|
{
|
|
this.SetIntezmeny(value);
|
|
}
|
|
FieldModified("IntezmenyId", value.ID);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
// ki kell törölni a kapcsolatot az adatbázisban
|
|
this.SetIntezmeny(null);
|
|
UpdateAssociations();
|
|
FieldModified("IntezmenyId", DBNull.Value);
|
|
}
|
|
}
|
|
}
|
|
#endregion
|
|
|
|
#region OsszefuggoSzakGyak (*) -> Tanev (1)
|
|
|
|
protected internal int m_TanevId = -1;
|
|
|
|
/// <summary>
|
|
/// A(z) Tanev asszociáció végpontjának ID-ja.
|
|
/// </summary>
|
|
/// <remarks>
|
|
/// - Insert() előtt célszerű kitölteni
|
|
/// - Update() nincs rá hatással: ezt a mezőt nem frissíti
|
|
/// - LoadByID() felhozza ezt a mezőt
|
|
/// </remarks>
|
|
public virtual int TanevId
|
|
{
|
|
get
|
|
{
|
|
return InternalTanevId;
|
|
}
|
|
set
|
|
{
|
|
InternalTanevId = value;
|
|
}
|
|
}
|
|
|
|
/// <summary>
|
|
/// Ez egy külön bejárat a DA számára
|
|
/// <summary>
|
|
internal int InternalTanevId
|
|
{
|
|
get
|
|
{
|
|
if (m_Tanev != null)
|
|
{
|
|
return m_Tanev.ID;
|
|
}
|
|
else
|
|
{
|
|
return m_TanevId;// XXX az meg nem teljesen OK
|
|
}
|
|
}
|
|
set
|
|
{
|
|
CheckModifyable();
|
|
if (m_TanevId != value)
|
|
{
|
|
m_TanevId = value;
|
|
m_Tanev = null;
|
|
FieldModified("TanevId", value);
|
|
}
|
|
}
|
|
}
|
|
|
|
/// <summary>
|
|
/// Ez egy külön bejárat a DA számára
|
|
/// <summary>
|
|
internal void ModifyTanev(Tanev value)
|
|
{
|
|
m_TanevId = value != null ? value.ID : -1;
|
|
m_Tanev = value;
|
|
FieldModified("TanevId", value != null ? (object)value.ID : DBNull.Value);
|
|
}
|
|
|
|
protected internal void SetTanev(Tanev value)
|
|
{
|
|
m_Tanev = value;
|
|
if (value != null)
|
|
{
|
|
m_TanevId = value.ID;
|
|
}
|
|
else
|
|
{
|
|
m_TanevId = -1;
|
|
}
|
|
}
|
|
|
|
protected Tanev m_Tanev = null;
|
|
|
|
ITanev IOsszefuggoSzakGyak.Tanev
|
|
{
|
|
get { return Tanev; }
|
|
set { Tanev = value as Tanev; }
|
|
}
|
|
|
|
/// <summary>
|
|
/// Nincs definiálva megjegyzés.
|
|
/// </summary>
|
|
/// <remarks>
|
|
/// Az UML modellben szereplő OsszefuggoSzakGyak és Tanev entitások közötti asszociáció megvalósítása.
|
|
/// </remarks>
|
|
[EntityProperty("Tanev", EntityPropertyBaseType.Entity, typeof(Tanev), EntityCopyMethod.ShallowCopy)]
|
|
public virtual Tanev Tanev
|
|
{
|
|
get
|
|
{
|
|
if ((m_Tanev == null) && (m_TanevId != -1))
|
|
{
|
|
SDA.Kreta.Entities.Tanev partner = SDA.Kreta.Entities.Tanev.GiveAnInstance();
|
|
partner.LoadByID(m_TanevId);
|
|
|
|
this.SetTanev(partner);
|
|
}
|
|
// természetesen null-t adunk vissza, ha nem tudtunk felhozni semmit
|
|
return m_Tanev;
|
|
}
|
|
set
|
|
{
|
|
CheckModifyable();
|
|
if (value != null)
|
|
{
|
|
if ((m_Tanev == null) || (value.ID != m_Tanev.ID))
|
|
{
|
|
if (value.State != EntityState.Initialized)
|
|
{
|
|
throw new EntityStateException(value.State);
|
|
}
|
|
if ((this.State != EntityState.New))
|
|
{
|
|
// Lista van a másik oldalon, úgyhogy a lista DA-ját használjuk
|
|
SDA.Kreta.Entities.Tanev_OsszefuggoSzakGyak_DA da = new Tanev_OsszefuggoSzakGyak_DA(value);
|
|
da.AddItem(this);
|
|
this.SetTanev(value);
|
|
}
|
|
else
|
|
{
|
|
this.SetTanev(value);
|
|
}
|
|
FieldModified("TanevId", value.ID);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
// ki kell törölni a kapcsolatot az adatbázisban
|
|
this.SetTanev(null);
|
|
UpdateAssociations();
|
|
FieldModified("TanevId", DBNull.Value);
|
|
}
|
|
}
|
|
}
|
|
#endregion
|
|
|
|
|
|
#region OsszefuggoSzakGyak (0..1) -> TanuloErtekeles (0..*)
|
|
protected IAssociatedEntityCollection<TanuloErtekeles> m_TanuloErtekeles = null;
|
|
|
|
IReadOnlyList<ITanuloErtekeles> IOsszefuggoSzakGyak.TanuloErtekeles => TanuloErtekeles.Cast<ITanuloErtekeles>().ToList();
|
|
|
|
/// <summary>
|
|
/// Nincs definiálva megjegyzés.
|
|
/// </summary>
|
|
/// <remarks>
|
|
/// Az UML modellben szereplő OsszefuggoSzakGyak és TanuloErtekeles entitások közötti asszociáció megvalósítása.
|
|
/// </remarks>
|
|
[EntityProperty("TanuloErtekeles", EntityPropertyBaseType.EntityCollection, typeof(IAssociatedEntityCollection<TanuloErtekeles>), EntityCopyMethod.DeepCopy, "OsszefuggoSzakGyakId")]
|
|
public virtual IAssociatedEntityCollection<TanuloErtekeles> TanuloErtekeles
|
|
{
|
|
get
|
|
{
|
|
if (m_TanuloErtekeles == null)
|
|
{
|
|
m_TanuloErtekeles = new AssociatedEntityCollection<OsszefuggoSzakGyak, TanuloErtekeles>(
|
|
new OsszefuggoSzakGyak_TanuloErtekeles_DA(this)
|
|
);
|
|
m_TanuloErtekeles.Load();
|
|
}
|
|
return m_TanuloErtekeles;
|
|
}
|
|
}
|
|
|
|
#endregion
|
|
|
|
#region OsszefuggoSzakGyak (0..1) -> ErtekelesTantargyi (*)
|
|
protected IAssociatedEntityCollection<ErtekelesTantargyi> m_ErtekelesTantargyi = null;
|
|
|
|
IReadOnlyList<IErtekelesTantargyi> IOsszefuggoSzakGyak.ErtekelesTantargyi => ErtekelesTantargyi.Cast<IErtekelesTantargyi>().ToList();
|
|
|
|
/// <summary>
|
|
/// Az értékelés összefüggő (egybefüggő) szakmai gyakorlatának az ID-ja. Csak szakmai gyakorlat mentésekor töltődik, mivel azokhoz lehet értékeléseket is felvenni.
|
|
/// </summary>
|
|
/// <remarks>
|
|
/// Az UML modellben szereplő OsszefuggoSzakGyak és ErtekelesTantargyi entitások közötti asszociáció megvalósítása.
|
|
/// </remarks>
|
|
[EntityProperty("ErtekelesTantargyi", EntityPropertyBaseType.EntityCollection, typeof(IAssociatedEntityCollection<ErtekelesTantargyi>), EntityCopyMethod.DeepCopy, "OsszefuggoSzakGyakId")]
|
|
public virtual IAssociatedEntityCollection<ErtekelesTantargyi> ErtekelesTantargyi
|
|
{
|
|
get
|
|
{
|
|
if (m_ErtekelesTantargyi == null)
|
|
{
|
|
m_ErtekelesTantargyi = new AssociatedEntityCollection<OsszefuggoSzakGyak, ErtekelesTantargyi>(
|
|
new OsszefuggoSzakGyak_ErtekelesTantargyi_DA(this)
|
|
);
|
|
m_ErtekelesTantargyi.Load();
|
|
}
|
|
return m_ErtekelesTantargyi;
|
|
}
|
|
}
|
|
|
|
#endregion
|
|
|
|
|
|
#endregion
|
|
|
|
#endregion
|
|
}
|
|
}
|
|
|