группировка динамических данных из списка - PullRequest
1 голос
/ 31 мая 2010

необходимо предоставить отношения мастер / потомок между списками

 Product  empID  Project Emp1D  projectID      taskname    taskID  
  abc      1      xyz     1      10                we       23
                  sfv     1      10               rr        56
                   ooo    1      1

  abc      2      xyz     2      11              we        33
                  sfv     3      11              rr        44
                  sfv     3      11              rr        55

У меня есть данные, поступающие из веб-сервиса, и затем все данные преобразуются в список.Теперь из списка необходимо указать отношения между ними

открытый класс SampleProjectData {public static ObservableCollection GetSampleData () {DateTime dtS = DateTime.Now;

            ObservableCollection<Product> teams = new ObservableCollection<Product>();
            teams.Add(new Product() { PDName = "Product1", OverallStartTime = dtS, OverallEndTime = dtS + TimeSpan.FromDays(3),  });


            Project emp = new Project() { PName = "Project1", OverallStartTime = dtS + TimeSpan.FromDays(1), OverallEndTime = dtS + TimeSpan.FromDays(6)  };
            emp.Tasks.Add(new Task() { StartTime = dtS, EndTime = dtS + TimeSpan.FromDays(2), TaskName = "John's Task 3" });
            emp.Tasks.Add(new Task() { StartTime = dtS + TimeSpan.FromDays(3), EndTime = dtS + TimeSpan.FromDays(4), TaskName = "John's Task 2" });
            teams[0].Projects.Add(emp);


            emp = new Project() { PName = "Project2", OverallStartTime = dtS + TimeSpan.FromDays(1.5), OverallEndTime = dtS + TimeSpan.FromDays(5.5) };
            emp.Tasks.Add(new Task() { StartTime = dtS + TimeSpan.FromDays(1), EndTime = dtS + TimeSpan.FromDays(4), TaskName = "Victor's Task" });
            teams[0].Projects.Add(emp);

            emp = new Project() { PName = "Project3", OverallStartTime = dtS + TimeSpan.FromDays(2), OverallEndTime = dtS + TimeSpan.FromDays(5) };
            emp.Tasks.Add(new Task() { StartTime = dtS + TimeSpan.FromDays(1), EndTime = dtS + TimeSpan.FromDays(4), TaskName = "Jason's Task 1" });
            emp.Tasks.Add(new Task() { StartTime = dtS + TimeSpan.FromDays(7), EndTime = dtS + TimeSpan.FromDays(9), TaskName = "Jason's Task 2" });
            teams[0].Projects.Add(emp);

            teams.Add(new Product() { PDName = "Product2", OverallStartTime = dtS, OverallEndTime = dtS + TimeSpan.FromDays(3) });

            emp = new Project() { PName = "Project4", OverallStartTime = dtS + TimeSpan.FromDays(0.5), OverallEndTime = dtS + TimeSpan.FromDays(3.5) };
            emp.Tasks.Add(new Task() { StartTime = dtS + TimeSpan.FromDays(1.5), EndTime = dtS + TimeSpan.FromDays(4), TaskName = "Vicky's Task" });
            teams[1].Projects.Add(emp);

            emp = new Project() { PName = "Project5", OverallStartTime = dtS + TimeSpan.FromDays(2), OverallEndTime = dtS + TimeSpan.FromDays(6) };
            emp.Tasks.Add(new Task() { StartTime = dtS + TimeSpan.FromDays(2.2), EndTime = dtS + TimeSpan.FromDays(3.8), TaskName = "Oleg's Task 1" });
            emp.Tasks.Add(new Task() { StartTime = dtS + TimeSpan.FromDays(5), EndTime = dtS + TimeSpan.FromDays(6), TaskName = "Oleg's Task 2" });
            emp.Tasks.Add(new Task() { StartTime = dtS + TimeSpan.FromDays(8), EndTime = dtS + TimeSpan.FromDays(9.6), TaskName = "Oleg's Task 3" });
            teams[1].Projects.Add(emp);

            emp = new Project() { PName = "Project6", OverallStartTime = dtS + TimeSpan.FromDays(2.5), OverallEndTime = dtS + TimeSpan.FromDays(4.5) };
            emp.Tasks.Add(new Task() { StartTime = dtS + TimeSpan.FromDays(0.8), EndTime = dtS + TimeSpan.FromDays(2), TaskName = "Kim's Task" });
            teams[1].Projects.Add(emp);


            teams.Add(new Product() { PDName = "Product3", OverallStartTime = dtS, OverallEndTime = dtS + TimeSpan.FromDays(3) });

            emp = new Project() { PName = "Project7", OverallStartTime = dtS + TimeSpan.FromDays(5), OverallEndTime = dtS + TimeSpan.FromDays(7.5) };
            emp.Tasks.Add(new Task() { StartTime = dtS + TimeSpan.FromDays(1.5), EndTime = dtS + TimeSpan.FromDays(4), TaskName = "Balaji's Task 1" });
            emp.Tasks.Add(new Task() { StartTime = dtS + TimeSpan.FromDays(5), EndTime = dtS + TimeSpan.FromDays(8), TaskName = "Balaji's Task 2" });
            teams[2].Projects.Add(emp);

            emp = new Project() { PName = "Project8", OverallStartTime = dtS + TimeSpan.FromDays(3), OverallEndTime = dtS + TimeSpan.FromDays(6.3) };
            emp.Tasks.Add(new Task() { StartTime = dtS + TimeSpan.FromDays(1.75), EndTime = dtS + TimeSpan.FromDays(2.25), TaskName = "Li's Task" });
            teams[2].Projects.Add(emp);

            emp = new Project() { PName = "Project9", OverallStartTime = dtS + TimeSpan.FromDays(2), OverallEndTime = dtS + TimeSpan.FromDays(6) };
            emp.Tasks.Add(new Task() { StartTime = dtS + TimeSpan.FromDays(2), EndTime = dtS + TimeSpan.FromDays(3), TaskName = "Stacy's Task" });
            teams[2].Projects.Add(emp);

            return teams;
        }
    }

выше - это пример данныхгде я группирую их со статическими данными таким же образом, мне нужно для данных CMG из БД, и мне нужно сохранить их список

все эти три данные объединены из разныхСервисы.и я храню их в списке, теперь у меня есть три таблицы данных
Product, Project, Task.
все данные поступают из веб-служб.я создал три списка, в которых я храню данные в списке.

Listobjpro = new List ();Listobjproduct = новый список ();LIstobjTask = новый список ();

Теперь мне нужно сопоставить эти таблицы.если вы видите выше.У меня есть объект Product в Product. Я добавил объект Project, а затем в объект Project я добавил объект задачи. Теперь из приведенных выше данных, которые хранятся в списке, мне нужно сделать то же отображение между классами.

и сгруппировать данные.

public class Product : INotifyPropertyChanged
    {
        public Product()
        {
            this.Projects = new ObservableCollection<Project>();
        }
        public string PDName { get; set; }
        public ObservableCollection<Project> Projects { get; set; }
        private DateTime _st;
        public DateTime OverallStartTime
        {
            get { return _st; }
            set
            {
                if (this._st != value)
                {
                    TimeSpan dur = this._et - this._st;
                    this._st = value;
                    this.OnPropertyChanged("OverallStartTime");
                    this.OverallEndTime = value + dur;
                }
            }
        }
        private DateTime _et;
        public DateTime OverallEndTime
        {
            get { return _et; }
            set
            {
                if (this._et != value)
                {
                    this._et = value;
                    this.OnPropertyChanged("OverallEndTime");
                }
            }
        }

        #region INotifyPropertyChanged Members

        protected void OnPropertyChanged(string name)
        {
            if (this.PropertyChanged != null)
                this.PropertyChanged(this, new PropertyChangedEventArgs(name));
        }
        public event PropertyChangedEventHandler PropertyChanged;

        #endregion
    }
    public class Project : INotifyPropertyChanged
    {
        public Project() { this.Tasks = new ObservableCollection<Task>(); }
        public string PName { get; set; }
        public ObservableCollection<Task> Tasks { get; set; }
        DateTime _st;
        public DateTime OverallStartTime
        {
            get { return _st; }
            set
            {
                if (this._st != value)
                {
                    TimeSpan dur = this._et - this._st;
                    this._st = value;
                    this.OnPropertyChanged("OverallStartTime");
                    this.OverallEndTime = value + dur;
                }
            }
        }
        DateTime _et;
        public DateTime OverallEndTime
        {
            get { return _et; }
            set
            {
                if (this._et != value)
                {
                    this._et = value;
                    this.OnPropertyChanged("OverallEndTime");
                }
            }
        }

        #region INotifyPropertyChanged Members

        protected void OnPropertyChanged(string name)
        {
            if (this.PropertyChanged != null)
                this.PropertyChanged(this, new PropertyChangedEventArgs(name));
        }

        public event PropertyChangedEventHandler PropertyChanged;

        #endregion
    }
    public class Task : INotifyPropertyChanged
    {
        public string TaskName { get; set; }
        DateTime _st;
        public DateTime StartTime
        {
            get { return _st; }
            set
            {
                if (this._st != value)
                {
                    TimeSpan dur = this._et - this._st;
                    this._st = value;
                    this.OnPropertyChanged("StartTime");
                    this.EndTime = value + dur;
                }
            }
        }
        private DateTime _et;
        public DateTime EndTime
        {
            get { return _et; }
            set
            {
                if (this._et != value)
                {
                    this._et = value;
                    this.OnPropertyChanged("EndTime");
                }
            }
        }

        #region INotifyPropertyChanged Members

        protected void OnPropertyChanged(string name)
        {
            if (this.PropertyChanged != null)
                this.PropertyChanged(this, new PropertyChangedEventArgs(name));
        }

        public event PropertyChangedEventHandler PropertyChanged;

        #endregion
    }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...