using System;
using System.Data;
using System.Data.SqlClient;
using Csla;
using Csla.Data;
namespace ProjectTracker.Library
{
/// <summary>
/// 此?类?的?主?要?功?能?用?于?给?Project提?供?对?其?关?联?子?对?象?的?集?合?的?一?个?维?护?和?映?射?,?Project----ProjectResources----ProjectResource
/// 她?是?一?个?集?合?,?是?父?对?象?组?织?子?对?象?的?一?个?集?合?
/// ,?提?供?用?于?托?管?包?含?的?子?类?,?比?较?,?添?加?,?删?除?子?对?象?等?
///
/// </summary>
[Serializable()]
public class ProjectResources : BusinessListBase<ProjectResources, ProjectResource>
{
#region Business Methods
/// <summary>
/// 获?得?一?个?项?目?集?合?中?的?项?目?资?源?对?象?(?)?
/// </summary>
/// <param name="resourceId">项?目?资?源?ID</param>
/// <returns></returns>
public ProjectResource GetItem(int resourceId)
{
//从?当?前?对?象?集?合?中?搜?索?其?中?的?子?对?象?,?比?较?参?数?ID,?相?等?则?返?回?
foreach (ProjectResource res in this)
if (res.ResourceId == resourceId)
return res;
return null;
}
/// <summary>
/// 通?过?指?定?的?ID值?,?像?当?前?集?合?中?加?入?子?对?象?,?分?配?
/// </summary>
/// <param name="resourceId">待?加?入?子?对?象?的?ID</param>
public void Assign(int resourceId)
{
if (!Contains(resourceId))
{
ProjectResource resource = ProjectResource.NewProjectResource(resourceId);
this.Add(resource);
}
else
throw new InvalidOperationException("资?源?已?经?在?项?目?中?存?在?");
}
/// <summary>
/// 从?集?合?中?移?除?一?个?资?源?子?对?象?
/// </summary>
/// <param name="resourceId">待?移?除?子?对?象?id</param>
public void Remove(int resourceId)
{
foreach (ProjectResource res in this)
{
if (res.ResourceId == resourceId)
{
//从?集?合?类?中?移?除?,?集?合?类?是?一?个?泛?型?,?由?于?BusinessListBase集?成?自?集?合?基?类?,?所?以?他?也?同?时?拥?有?集?合?的?方?法?
//Remove,Add等?,?这?个?操?作?应?该?将?数?据?放?到?DEleteList中?
Remove(res);
break;
}
}
}
/// <summary>
/// 检?查?集?合?中?是?否?包?含?此?子?对?象?,?如?果?包?含?返?回?True,?否?则?返?回?false
/// </summary>
/// <param name="resourceId">子?对?象?ID,?资?源?id用?的?是?整?型?</param>
/// <returns></returns>
public bool Contains(int resourceId)
{
foreach (ProjectResource res in this)
if (res.ResourceId == resourceId)
return true;
return false;
}
/// <summary>
/// 在?删?除?已?删?除?的?集?合?中?搜?索?子?对?象?的?存?在?
/// </summary>
/// <param name="resourceId"></param>
/// <returns></returns>
public bool ContainsDeleted(int resourceId)
{
foreach (ProjectResource res in DeletedList)
if (res.ResourceId == resourceId)
return true;
return false;
}
#endregion
#region Factory Methods
/// <summary>
/// 内?联?工?厂?,?代?表?同?一?个?程?序?集?中?调?用?,?因?为?他?只?是?提?供?给?project对?象?在?创?建?的?时?候?同?时?被?创?建?的?一?个?方?法?,?调?用?请?看?project
/// 而?UI不?会?去?使?用?她?
/// </summary>
/// <returns></returns>
internal static ProjectResources NewProjectResources()
{
return new ProjectResources();
}
/// <summary>
/// 通?过?dr获?得?一?个?集?合?
/// </summary>
/// <param name="dr"></param>
/// <returns></returns>
internal static ProjectResources GetProjectResources(SafeDataReader dr)
{
//调?用?带?参?数?的?构?造?器?
return new ProjectResources(dr);
}
/// <summary>
/// 默?认?构?造?器?
/// </summary>
private ProjectResources()
{
//标?记?为?子?关?系?
MarkAsChild();
}
/// <summary>
/// 带?参?数?的?构?造?器?
/// </summary>
/// <param name="dr"></param>
private ProjectResources(SafeDataReader dr)
{
MarkAsChild();
Fetch(dr);
}
#endregion
#region Data Access
// c从?数?据?看?加?载?数?据?
private void Fetch(SafeDataReader dr)
{
//将?列?表?更?改?事?件?暂?时?设?置?为?失?效?,?增?加?效?率?(?)?
this.RaiseListChangedEvents = false;
while (dr.Read())
this.Add(ProjectResource.GetResource(dr));//DR传?个?子?对?象?用?于?初?始?化?一?个?子?对?象?
//启?用?事?件?
this.RaiseListChangedEvents = true;
}
/// <summary>
/// (?)?,?这?个?方?法?是?内?联?方?法?,?因?为?她?只?是?Project来?调?用?的?
/// 托?管?让?每?一?个?子?对?象?都?做?相?应?的?操?作?
/// </summary>
/// <param name="project"></param>
internal void Update(Project project)
{
this.RaiseListChangedEvents = false;
// update (thus deleting) any deleted child objects
//从?已?删?除?列?表?中?轮?寻?每?一?个?元?素?调?用?其?删?除?自?身?方?法?,?注?意?他?们?要?传?入?其?关?联?的?项?目?对?象?
foreach (ProjectResource obj in DeletedList)
obj.DeleteSelf(project);//从?数?据?库?中?删?除?(?)?
// now that they are deleted, remove them from memory too
//将?DeletedList从?系?统?缓?存?中?移?除?掉?所?有?的?元?素?,?deletedList被?清?空?,?同?步?数?据?库?
DeletedList.Clear();
// add/update any current child objects
// 再?来?看?看?添?加?和?更?新?是?如?何?实?现?的?,?同?样?要?传?入?相?应?关?联?的?项?目?对?象?
// 轮?寻?每?一?个?子?元?素?,?查?看?其?标?志?,?如?果?是?新?的?就?调?用?子?对?象?的?插?入?方?法?
// 如?果?不?是?新?的?,?那?么?就?调?用?更?新?方?法?
foreach (ProjectResource obj in this)
{
//根?据?子?对?象?的?状?态?调?用?合?适?的?方?法?
if (obj.IsNew)
obj.Insert(project);
else
obj.Update(project);
}
this.RaiseListChangedEvents = true;
}
#endregion
}
}
using System;
using System.Data;
using System.Data.SqlClient;
using Csla;
using Csla.Data;
using Csla.Validation;
namespace ProjectTracker.Library
{
/// <summary>
/// 此?类?为?分?配?资?源?类?,?用?于?和?ProjectResources类?合?作?为?Project处?理?分?配?给?项?目?的?资?源?的?类?、?
/// 集?成?子?业?务?基?类?,?与?project是?相?同?的?,?但?是?她?还?集?成?自?一?个?IholdRoles接?口?
/// 这?个?类?只?提?供?给?ProjectResources使?用?
/// </summary>
[Serializable()]
public class ProjectResource : BusinessBase<ProjectResource>, IHoldRoles
{
#region Business Methods
private int _resourceId;//资?源?id
private string _firstName = string.Empty;//名?字?
private string _lastName = string.Empty;//姓?氏?
private SmartDate _assigned;//分?配?日?期?
private int _role;//职?位?
private byte[] _timestamp = new byte[8];//时?间?戳?,?用?于?处?理?并?发?修?改?的?情?况?,?先?写?者?赢?的?乐?观?并?发?
//表?明?特?性?,?表?示?是?主?键?,?但?是?并?不?一?定?是?唯?一?的?可?识?别?值?
[System.ComponentModel.DataObjectField(false, true)]
public int ResourceId
{
[System.Runtime.CompilerServices.MethodImpl(System.Runtime.CompilerServices.MethodImplOptions.NoInlining)]
get
{
CanReadProperty(true);
return _resourceId;
}
}
public string FirstName
{
[System.Runtime.CompilerServices.MethodImpl(System.Runtime.CompilerServices.MethodImplOptions.NoInlining)]
get
{
CanReadProperty(true);
return _firstName;
}
}
public string LastName
{
[System.Runtime.CompilerServices.MethodImpl(System.Runtime.CompilerServices.MethodImplOptions.NoInlining)]
get
{
CanReadProperty(true);
return _lastName;
}
}
/// <summary>
/// 全?名?属?性?
/// </summary>
public string FullName
{
[System.Runtime.CompilerServices.MethodImpl(System.Runtime.CompilerServices.MethodImplOptions.NoInlining)]
get
{
if (CanReadProperty("FirstName") && CanReadProperty("LastName"))
return string.Format("{0}, {1}", LastName, FirstName);
else
throw new System.Security.SecurityException( "没?有?读?取?权?限?");
}
}
/// <summary>
/// 分?配?日?期?
/// </summary>
public string Assigned
{
[System.Runtime.CompilerServices.MethodImpl(System.Runtime.CompilerServices.MethodImplOptions.NoInlining)]
get
{
CanReadProperty(true);
//获?取?时?间?的?文?本?
return _assigned.Text;
}
}
public int Role
{
[System.Runtime.CompilerServices.MethodImpl(System.Runtime.CompilerServices.MethodImplOptions.NoInlining)]
get
{
CanReadProperty(true);
return _role;
}
[System.Runtime.CompilerServices.MethodImpl(System.Runtime.CompilerServices.MethodImplOptions.NoInlining)]
set
{
CanWriteProperty(true);
//如?果?不?重?复?则?更?改?
if (!_role.Equals(value))
{
_role = value;
//1调?用?对?数?据?验?证?规?则?的?检?查?AddBusinessRules,2,IsDirty标?记?已?经?修?改?,
//3,出?发?属?性?更?改?事?件?提?供?给?UI刷?新?的?警?示?(411),?发?生?变?化?就?要?调?用?此?方?法?
PropertyHasChanged();
}
}
}
//获?得?资?源?
public Resource GetResource()
{
return Resource.GetResource(_resourceId);
}
//提?供?Id,?是?为?了?支?持?Object的?,?Equals().toString(),GetHashCode()
protected override object GetIdValue()
{
return _resourceId;
}
#endregion
#region Validation Rules
protected override void AddBusinessRules()
{
//通?过?RuleHandler委?托?,?调?用?Assignment.ValidRole方?法?,?对?Role进?行?验?证?,?这?个?方?法?在?Assignment中?定?义?,?你?可?以?看?一?下?,?是?公?用?的?方?法?
//如?果?返?回?false的?话?就?是?代?表?验?证?失?败?,?true验?证?成?功?
ValidationRules.AddRule( new Csla.Validation.RuleHandler( Assignment.ValidRole), "Role");
}
#endregion
#region Authorization Rules
protected override void AddAuthorizationRules()
{
//只?有?ProjectManager,?才?有?权?限?修?改?Role
AuthorizationRules.AllowWrite( "Role", "ProjectManager");
}
#endregion
#region Factory Methods
internal static ProjectResource NewProjectResource(int resourceId)
{
//调?用?构?造?器?初?始?化?,?,?获?得?一?个?资?源?,?,?给?予?一?个?默?认?职?位?
return new ProjectResource( Resource.GetResource(resourceId), RoleList.DefaultRole());
}
internal static ProjectResource GetResource(SafeDataReader dr)
{
//调?用?构?造?器?初?始?化?
return new ProjectResource(dr);
}
//默?认?构?造?
private ProjectResource()
{
//标?记?为?子?很?重?要?,?必?须?的?
MarkAsChild();
}
/// <summary>
/// 通?过?一?个?已?有?资?源?,?和?一?个?职?位?来?构?造?一?个?ProjectResource
/// </summary>
/// <param name="resource"></param>
/// <param name="role"></param>
private ProjectResource(Resource resource, int role)
{
MarkAsChild();
_resourceId = resource.Id;
_lastName = resource.LastName;
_firstName = resource.FirstName;
_assigned.Date = Assignment.GetDefaultAssignedDate();
_role = role;
}
/// <summary>
/// 单?参?数?构?造?,?这?个?时?候?DR是?一?个?记?录?
/// </summary>
/// <param name="dr"></param>
private ProjectResource(SafeDataReader dr)
{
MarkAsChild();
Fetch(dr);
}
#endregion
#region Data Access
private void Fetch(SafeDataReader dr)
{
_resourceId = dr.GetInt32("ResourceId");
_lastName = dr.GetString("LastName");
_firstName = dr.GetString("FirstName");
_assigned = dr.GetSmartDate("Assigned");
_role = dr.GetInt32("Role");
//非?常?标?准?的?时?间?戳?
dr.GetBytes("LastChanged", 0, _timestamp, 0, 8);
//做?旧?,?因?为?此?对?象?与?数?据?库?是?数?据?同?步?的?
MarkOld();
}
/// <summary>
/// 内?联?的?,?当?其?父?对?象?调?用?此?对?象?时?候?判?断?对?象?状?态?,?isDeleted=false isnew=true,?调?用?此?方?法?
/// </summary>
/// <param name="project"></param>
internal void Insert(Project project)
{
// if we're not dirty then don't update the database
//如?果?当?前?对?象?不?脏?也?就?是?没?有?给?其?付?过?值?,?没?有?必?要?更?新?到?数?据?库?
if (!this.IsDirty) return;
using (SqlConnection cn = new SqlConnection(Database.PTrackerConnection))
{
cn.Open();
//调?用?分?派?类?中?的?方?法?,?并?且?返?回?时?间?戳?
//参?数?是?连?接?,?项?目?id父?id,?资?源?id子?id,?分?配?时?间?,?角?色?
_timestamp = Assignment.AddAssignment(cn, project.Id, _resourceId, _assigned, _role);
//做?旧?This对?象?,?因?为?她?已?经?与?数?据?库?同?步?,?也?就?是?说?她?已?经?在?数?据?库?中?了?,?不?是?新?的?数?据?库?
//这?个?方?法?如?果?是?在?根?对?象?数?据?门?户?会?自?动?调?用?,?但?是?子?对?象?需?要?手?动?
//这?个?方?法?会?将?isNew标?记?,?和?IsDirty标?记?设?置?为?False,?因?为?这?时?,?这?个?数?据?既?不?是?新?的?也?不?是?脏?的?
MarkOld();
}
}
internal void Update(Project project)
{
// if we're not dirty then don't update the database
if (!this.IsDirty) return;
using (SqlConnection cn = new SqlConnection(Database.PTrackerConnection))
{
cn.Open();
//与?Insert同?理?
_timestamp = Assignment.UpdateAssignment(cn, project.Id, _resourceId, _assigned, _role, _timestamp);
MarkOld();
}
}
internal void DeleteSelf(Project project)
{
// if we're not dirty then don't update the database
if (!this.IsDirty) return;
// if we're new then don't update the database
if (this.IsNew) return;
using (SqlConnection cn = new SqlConnection(Database.PTrackerConnection))
{
cn.Open();
Assignment.RemoveAssignment(cn, project.Id, _resourceId);
MarkNew();
}
}
#endregion
}
}
//此?业?务?类?实?现?与?.0完?全?一?致?
using System;
using System.Collections.Generic;
using System.Text;
using System.Data;
using System.Data.SqlClient;
using Csla;
using Csla.Validation;
using Csla.Data;
using System.Reflection;
namespace ProjectTracker.Library
{
//定?义?这?个?接?口?是?为?了?使?子?类?提?供?,?可?以?提?供?对?Role属?性?的?访?问?
internal interface IHoldRoles
{
int Role { get; set; }
}
/// <summary>
/// 这?个?类?定?义?为?内?联?的?,?同?时?是?静?态?的?,?是?因?为?这?个?类?是?提?供?了?ProjectResource和?ResourceAssignmet的?通?用?方?法?的?集?合?,?因?为?
/// 这?个?两?个?对?象?都?在?操?作?这?相?同?的?数?据?,?一?个?资?源?属?于?某?个?项?目?,?和?一?个?项?目?拥?有?多?少?资?源?在?是?一?个?含?义?
/// 静?态?类?,?是?因?为?这?个?类?没?有?任?何?私?有?变?量?,?也?就?是?数?据?域?,?所?以?声?明?为?静?态?方?便?使?用?
/// 此?对?象?对?Assignment表?进?行?操?作?,?这?个?表?是?一?个?中?间?表?,?用?来?存?储?多?对?多?的?表?数?据?映?射?
/// 通?用?原?则?
/// </summary>
internal static class Assignment
{
#region Business Methods
/// <summary>
/// 获?得?默?认?的?分?配?时?间?
/// </summary>
/// <returns></returns>
public static DateTime GetDefaultAssignedDate()
{
return DateTime.Today;
}
#endregion
#region Validation Rules
/// <summary>
/// Ensure the Role property value exists
/// in RoleList
/// 像?上?面?的?英?文?解?释?一?样?,?这?个?验?证?确?保?了?Role在?RoleList中?可?以?被?找?到?
/// 这?个?方?法?是?一?个?公?用?的?验?证?方?法?ProjectResource和?ResourceAssignmet通?过?委?托?来?调?用?这?个?方?法?验?证?
/// </summary>
public static bool ValidRole(object target, RuleArgs e)
{
int role = ((IHoldRoles)target).Role;
//通?过?RoleList的?GetList获?得?List对?象?,?RolesList对?象?拥?有?的?ContainsKey方?法?可?以?判?断?此?id在?列?表?中?是?否?存?在?
if (RoleList.GetList().ContainsKey(role))
return true;
else
{
e.Description = "职?务?必?须?在?职?务?列?表?中?存?在?";
return false;
}
}
#endregion
#region Data Access
/// <summary>
/// 添?加?一?个?分?配?
/// </summary>
/// <param name="cn">连?接?</param>
/// <param name="projectId">项?目?id</param>
/// <param name="resourceId">资?源?id</param>
/// <param name="assigned">分?配?时?间?</param>
/// <param name="role">职?位?</param>
/// <returns></returns>
public static byte[] AddAssignment(SqlConnection cn, Guid projectId, int resourceId, SmartDate assigned, int role)
{
using (SqlCommand cm = cn.CreateCommand())
{
cm.CommandText = "addAssignment";
return DoAddUpdate(cm, projectId, resourceId, assigned, role);
}
}
/// <summary>
/// 更?新?一?个?分?配?
/// </summary>
/// <param name="cn">连?接?</param>
/// <param name="projectId">项?目?id</param>
/// <param name="resourceId">资?源?id</param>
/// <param name="assigned">分?配?时?间?</param>
/// <param name="newRole">更?新?后?的?职?位?</param>
/// <param name="timestamp">时?间?戳?</param>
/// <returns></returns>
public static byte[] UpdateAssignment(SqlConnection cn, Guid projectId, int resourceId, SmartDate assigned, int newRole, byte[] timestamp)
{
using (SqlCommand cm = cn.CreateCommand())
{
cm.CommandText = "updateAssignment";
cm.Parameters.AddWithValue("@lastChanged", timestamp);
return DoAddUpdate( cm, projectId, resourceId, assigned, newRole);
}
}
/// <summary>
/// 添?加?和?更?新?的?公?共?方?法?
/// </summary>
/// <param name="cm"></param>
/// <param name="projectId"></param>
/// <param name="resourceId"></param>
/// <param name="assigned"></param>
/// <param name="newRole"></param>
/// <returns></returns>
private static byte[] DoAddUpdate(SqlCommand cm, Guid projectId, int resourceId, SmartDate assigned, int newRole)
{
cm.CommandType = CommandType.StoredProcedure;
cm.Parameters.AddWithValue("@projectId", projectId);
cm.Parameters.AddWithValue("@resourceId", resourceId);
cm.Parameters.AddWithValue("@assigned", assigned.DBValue);
cm.Parameters.AddWithValue("@role", newRole);
//时?间?戳?返?回?值?
SqlParameter param = new SqlParameter("@newLastChanged", SqlDbType.Timestamp);
param.Direction = ParameterDirection.Output;
cm.Parameters.Add(param);
cm.ExecuteNonQuery();
return (byte[])cm.Parameters["@newLastChanged"].Value;
}
/// <summary>
/// 删?除?一?个?分?配?
/// </summary>
/// <param name="cn"></param>
/// <param name="projectId"></param>
/// <param name="resourceId"></param>
public static void RemoveAssignment(SqlConnection cn, Guid projectId, int resourceId)
{
using (SqlCommand cm = cn.CreateCommand())
{
cm.CommandType = CommandType.StoredProcedure;
cm.CommandText = "deleteAssignment";
cm.Parameters.AddWithValue("@projectId", projectId);
cm.Parameters.AddWithValue("@resourceId", resourceId);
cm.ExecuteNonQuery();
}
}
#endregion
}
}
代码下载:CSLA3.0中文学习演示程序1.2.rar