GetParentRow() public method

Gets the parent row of this using the specified .
public GetParentRow ( DataRelation relation ) : DataRow
relation DataRelation
return DataRow
コード例 #1
0
ファイル: BaseBusinessProxy.cs プロジェクト: joeiren/ePort
        public BaseBusinessProxy(DataRow row)
        {
            this.Name = row["Name"].ToString();

            this.Version = "";
            if (row.GetParentRow("Bla_Blh").Table.Columns.Contains("Version"))
            {
                this.Version = row.GetParentRow("Bla_Blh")["Version"].ToString();
            }
            this.DbName = "";
            if (row.Table.Columns.Contains("DbName"))
            {
                this.DbName = row["DbName"].ToString();
            }
            this.TransactionMode = "false";
            if (row.Table.Columns.Contains("TransactionMode"))
            {
                this.TransactionMode = row["TransactionMode"].ToString();
            }
            if (row.Table.Columns.Contains("Provider"))
            {
                this.Provider = row["Provider"].ToString();
            }
            try
            {
                this.BusinessAssemblyName = row.GetParentRow("Bla_Blh")["Name"].ToString();
            }
            catch { }
        }
コード例 #2
0
        private void AddChangedRow(Hashtable addedRows, DataTable copyTable, DataRow row)
        {
            if (addedRows.ContainsKey(row))
            {
                return;
            }

            foreach (DataRelation relation in row.Table.ParentRelations)
            {
                DataRow parent = (row.RowState != DataRowState.Deleted ?
                                  row.GetParentRow(relation) :
                                  row.GetParentRow(relation, DataRowVersion.Original)
                                  );
                if (parent == null)
                {
                    continue;
                }
                // add the parent row
                DataTable parentCopyTable = copyTable.DataSet.Tables [parent.Table.TableName];
                AddChangedRow(addedRows, parentCopyTable, parent);
            }

            // add the current row
            DataRow newRow = copyTable.NewNotInitializedRow();

            copyTable.Rows.AddInternal(newRow);
            // Don't check for ReadOnly, when cloning data to new uninitialized row.
            row.CopyValuesToRow(newRow, false);
            newRow.XmlRowID = row.XmlRowID;
            addedRows.Add(row, row);
        }
コード例 #3
0
        internal void CheckForLoops(DataRelation rel)
        {
            // don't check for loops in the diffgram
            // because there may be some holes in the rowCollection
            // and index creation may fail. The check will be done
            // after all the loading is done _and_ we are sure there
            // are no holes in the collection.
            if (this._Table.DataSet.fInLoadDiffgram)
            {
                return;
            }
            int count = this.Table.Rows.Count, i = 0;
            // need to optimize this for count > 100
            DataRow parent = this.GetParentRow(rel);

            while (parent != null)
            {
                if ((parent == this) || (i > count))
                {
                    throw ExceptionBuilder.NestedCircular(this.Table.TableName);
                }
                i++;
                parent = parent.GetParentRow(rel);
            }
        }
コード例 #4
0
        internal override object Eval(DataRow row, DataRowVersion version)
        {
            if ((this.column == null) || (this.relation == null))
            {
                throw ExprException.ExpressionUnbound(this.ToString());
            }
            DataRow parentRow = row.GetParentRow(this.relation, version);

            if (parentRow == null)
            {
                return(DBNull.Value);
            }
            return(parentRow[this.column, parentRow.HasVersion(version) ? version : DataRowVersion.Current]);
        }
コード例 #5
0
 internal void CheckForLoops(DataRelation rel)
 {
     if (!this._table.fInLoadDiffgram && ((this._table.DataSet == null) || !this._table.DataSet.fInLoadDiffgram))
     {
         int count = this._table.Rows.Count;
         int num   = 0;
         for (DataRow row = this.GetParentRow(rel); row != null; row = row.GetParentRow(rel))
         {
             if ((row == this) || (num > count))
             {
                 throw ExceptionBuilder.NestedCircular(this._table.TableName);
             }
             num++;
         }
     }
 }
コード例 #6
0
        internal override object Eval(DataRow row, DataRowVersion version)
        {
            if (_column == null || _relation == null)
            {
                throw ExprException.ExpressionUnbound(ToString());
            }

            DataRow parent = row.GetParentRow(_relation, version);

            if (parent == null)
            {
                return(DBNull.Value);
            }

            return(parent[_column, parent.HasVersion(version) ? version : DataRowVersion.Current]);
        }
コード例 #7
0
        internal override object Eval(DataRow row, DataRowVersion version)
        {
#if DEBUG
            if (CompModSwitches.LookupNode.TraceVerbose)
            {
                Debug.WriteLine("Eval " + this.ToString());
            }
#endif

            if (table == null || column == null || relation == null)
            {
                throw ExprException.ExpressionUnbound(this.ToString());
            }

            DataRow parent = row.GetParentRow(relation, version);
            if (parent == null)
            {
                return(DBNull.Value);
            }

            return(parent[column, parent.HasVersion(version) ? version : DataRowVersion.Current]); // haroona : Bug 76154
        }
コード例 #8
0
ファイル: XmlDataDocument.cs プロジェクト: ericeil/corefx
 private DataRow GetNestedParent(DataRow row)
 {
     DataRelation relation = GetNestedParentRelation(row);
     if (relation != null)
         return row.GetParentRow(relation);
     return null;
 }
コード例 #9
0
ファイル: CustomSiteMapProvider.cs プロジェクト: popovegor/gt
        private CustomSiteMapNode GetParentNodeFromDataRow(DataRow childRow)
        {
            if (childRow == null)
            throw new ProviderException("DataRow in SiteMap is null.");

              DataRow parentRow = childRow.GetParentRow(GT.DA.SiteMap.SiteMap.PARENT_CHILD_REL);
              if (parentRow == null)
            throw new ProviderException(string.Format("Cannot find parent for SiteMap node with ID {0}",
                                                  childRow[GT.DA.SiteMap.SiteMap.ID_COL]));

              return CreateNodeFromRow(parentRow);
        }
コード例 #10
0
 internal override object Eval(DataRow row, DataRowVersion version)
 {
     if ((this.column == null) || (this.relation == null))
     {
         throw ExprException.ExpressionUnbound(this.ToString());
     }
     DataRow parentRow = row.GetParentRow(this.relation, version);
     if (parentRow == null)
     {
         return DBNull.Value;
     }
     return parentRow[this.column, parentRow.HasVersion(version) ? version : DataRowVersion.Current];
 }
コード例 #11
0
		private void AddChangedRow (Hashtable addedRows, DataTable copyTable, DataRow row)
		{
			if (addedRows.ContainsKey (row)) return;

			foreach (DataRelation relation in row.Table.ParentRelations) {
				DataRow parent = row.GetParentRow (relation);
				if (parent == null)
					continue;
				// add the parent row
				DataTable parentCopyTable = copyTable.DataSet.Tables [parent.Table.TableName];
				AddChangedRow (addedRows, parentCopyTable, parent);
			}

			// add the current row
			DataRow newRow = copyTable.NewNotInitializedRow();
			copyTable.Rows.AddInternal(newRow);
			row.CopyValuesToRow (newRow);
			newRow.XmlRowID = row.XmlRowID;
			addedRows.Add (row, row);
		}
コード例 #12
0
        internal virtual void Evaluate(DataRow row, DataRowVersion version)
        {
#if DEBUG
            if (CompModSwitches.DataExpression.TraceVerbose)
            {
                Debug.WriteLine("Evaluate expression column Queue, version = " + version.ToString() + " for table " + owner.TableName);
            }
#endif
            Debug.Assert(columns != null, "Invalid dependensy list");
            Debug.Assert(row != null, "Invalid argument to Evaluate, row");
            for (int i = 0; i < columnCount; i++)
            {
                DataColumn col = columns[i];
                Debug.Assert(col.Computed, "Only computed columns should be in the queue.");

#if DEBUG
                if (CompModSwitches.DataExpression.TraceVerbose)
                {
                    Debug.WriteLine("Evaluate column " + col.ColumnName + " = " + col.DataExpression.ToString());
                }
#endif

                if (col.Table == null)
                {
                    continue;
                }

                if (col.Table != owner)
                {
                    // first if the column belongs to an other table we need to recalc it for each row in the foreing table

#if DEBUG
                    if (CompModSwitches.DataExpression.TraceVerbose)
                    {
                        Debug.WriteLine("the column belong to a different table %%%%%%%");
                    }
#endif
                    // we need to update all foreign table - NOPE, only those who are valid parents. ALTHOUGH we're skipping old parents right now... confirm.
                    DataRowVersion foreignVer = (version == DataRowVersion.Proposed) ? DataRowVersion.Default : version;

                    int parentRelationCount = owner.ParentRelations.Count;
                    for (int j = 0; j < parentRelationCount; j++)
                    {
                        DataRelation relation = owner.ParentRelations[j];
                        if (relation.ParentTable != col.Table)
                        {
                            continue;
                        }
                        DataRow parentRow = row.GetParentRow(relation, version);
                        if (parentRow != null)
                        {
                            col[parentRow.GetRecordFromVersion(foreignVer)] = col.DataExpression.Evaluate(parentRow, foreignVer);
                        }
                    }

                    int childRelationCount = owner.ChildRelations.Count;
                    for (int j = 0; j < childRelationCount; j++)
                    {
                        DataRelation relation = owner.ChildRelations[j];
                        if (relation.ChildTable != col.Table)
                        {
                            continue;
                        }
                        DataRow[] childRows = row.GetChildRows(relation, version);
                        for (int k = 0; k < childRows.Length; k++)
                        {
                            if (childRows[k] != null)
                            {
                                col[childRows[k].GetRecordFromVersion(foreignVer)] = col.DataExpression.Evaluate(childRows[k], foreignVer);
                            }
                        }
                    }
                }
                else if (col.DataExpression.HasLocalAggregate())
                {
                    // if column expression references a local Table aggregate we need to recalc it for the each row in the local table

                    DataRowVersion aggVersion = (version == DataRowVersion.Proposed) ? DataRowVersion.Default : version;
#if DEBUG
                    if (CompModSwitches.DataExpression.TraceVerbose)
                    {
                        Debug.WriteLine("it has local aggregate.");
                    }
#endif
                    bool   isConst = col.DataExpression.IsTableAggregate();
                    object val     = null;

                    if (isConst)
                    {
                        val = col.DataExpression.Evaluate(row, aggVersion);
                    }

                    DataRow[] rows = new DataRow[col.Table.Rows.Count];
                    col.Table.Rows.CopyTo(rows, 0);

                    for (int j = 0; j < rows.Length; j++)
                    {
                        if (!isConst)
                        {
                            val = col.DataExpression.Evaluate(rows[j], aggVersion);
                        }
                        col[rows[j].GetRecordFromVersion(aggVersion)] = val;
                    }
                }
                else
                {
                    col[row.GetRecordFromVersion(version)] = col.DataExpression.Evaluate(row, version);
                }
            }
        }
コード例 #13
0
ファイル: frmAdmin.cs プロジェクト: Dr1N/CinemaTickets
 /// <summary>
 /// Вернуть название объекта представленного в виде значения ключа
 /// </summary>
 /// <param name="dr">Строка описывающая сущность</param>
 /// <param name="columnIndex">Индекс столбца в строке, значение в котором нужно вернуть в виде текста</param>
 /// <returns>Текстовое представление столбца из заданной строки</returns>
 private string GetColumnText(DataRow dr, int columnIndex)
 {
     DataTable table = dr.Table;
     switch (table.TableName)
     {
         case "Movies":
             if (table.Columns[columnIndex].ColumnName == "genre_id")
             {
                 DataRow genre = dr.GetParentRow("MovieGenre");
                 return genre["name"].ToString();
             }
             break;
         case "Sessions":
             if (table.Columns[columnIndex].ColumnName == "movie_id")
             {
                 DataRow movie = dr.GetParentRow("SessionMovie");
                 return movie["name"].ToString();
             }
             else if (table.Columns[columnIndex].ColumnName == "cinema_id")
             {
                 DataRow cinema = dr.GetParentRow("SessionCinema");
                 return cinema["name"].ToString();
             }
             else if (table.Columns[columnIndex].ColumnName == "beginning")
             {
                 DateTime begin = this.dataBase.GetDateFromSecond((int)dr["beginning"]);
                 return begin.ToLongDateString() + " " + begin.ToShortTimeString();
             }
             break;
         case "Tickets":
             if (table.Columns[columnIndex].ColumnName == "session_id")
             {
                 DataRow session = dr.GetParentRow("TicketSession");
                 DataRow movie = session.GetParentRow("SessionMovie");
                 DataRow cinema = session.GetParentRow("SessionCinema");
                 DateTime time = this.dataBase.GetDateFromSecond((int)session["beginning"]);
                 string column = String.Format("{0} ({1}) [{2}]", movie["name"].ToString(), cinema["name"].ToString(), time.ToShortDateString() + " " + time.ToShortTimeString());
                 return column;
             }
             break;
         default:
             break;
     }
     return dr[columnIndex].ToString();
 }
コード例 #14
0
        internal override object Eval(DataRow row, DataRowVersion version) {
            if (column == null || relation == null)
                throw ExprException.ExpressionUnbound(this.ToString());

            DataRow parent = row.GetParentRow(relation, version);
            if (parent == null)
                return DBNull.Value;

            return parent[column, parent.HasVersion(version) ? version : DataRowVersion.Current]; // [....] : Bug 76154
        }
コード例 #15
0
        /// <summary>
        /// private Methode um die zugehörige Adresse, zu einer Zeile (Row) aus der lokalen Datenbank-Kunden-Tabelle, zu erhalten
        /// </summary>
        /// <param name="row"></param>
        /// <returns></returns>
        private Adresse GetAdress(DataRow row)
        {
            DataRow r = row.GetParentRow(_zuordnungKundenAdresse);

            return new Adresse(r["Straße"].ToString(), r["Hausnummer"].ToString(), r["Ort"].ToString(), r["PLZ"].ToString());
        }
コード例 #16
0
ファイル: DataSet.cs プロジェクト: t-ashula/mono
		private void AddChangedRow (Hashtable addedRows, DataTable copyTable, DataRow row)
		{
			if (addedRows.ContainsKey (row))
				return;

			foreach (DataRelation relation in row.Table.ParentRelations) {
				DataRow parent = ( row.RowState != DataRowState.Deleted ?
						   row.GetParentRow (relation) :
						   row.GetParentRow (relation, DataRowVersion.Original)
						   );
				if (parent == null)
					continue;
				// add the parent row
				DataTable parentCopyTable = copyTable.DataSet.Tables [parent.Table.TableName];
				AddChangedRow (addedRows, parentCopyTable, parent);
			}

			// add the current row
			DataRow newRow = copyTable.NewNotInitializedRow ();
			copyTable.Rows.AddInternal (newRow);
			// Don't check for ReadOnly, when cloning data to new uninitialized row.
			row.CopyValuesToRow (newRow, false);
			newRow.XmlRowID = row.XmlRowID;
			addedRows.Add (row, row);
		}
コード例 #17
0
ファイル: Utilities.cs プロジェクト: bmanojlovic/bforce8583
        public static string CodeToText(DataRow Row, string ColumnName, string TextCol, bool bIndirect)
        {
            string RetVal = "";
            DataTable Table = Row.Table;

            for (int I = 0; I < Table.ParentRelations.Count; I++)
            {
                DataRelation Rel = Table.ParentRelations[I];

                if (Rel.ChildKeyConstraint.Columns.Length == 1 &&
                    Rel.ChildKeyConstraint.Columns[0].ColumnName.ToLower().CompareTo(ColumnName.ToLower()) == 0)
                {
                    DataRow ParentRow = Row.GetParentRow(Rel);
                    try
                    {
                        RetVal = ParentRow[TextCol].ToString();
                        if (bIndirect)
                            return CodeToText(ParentRow, TextCol, "Text", false);
                    }
                    catch
                    {
                    }
                    break;
                }
            }
            return RetVal;
        }
コード例 #18
0
		public DataRow GetReferencedRow (DataRow row)
		{
			switch (refTable) {
			case ReferencedTable.Self:
			default:
				return row;

			case ReferencedTable.Parent:
				return row.GetParentRow (GetRelation (row));

			case ReferencedTable.Child:
				return row.GetChildRows (GetRelation (row)) [0];
			}
		}
コード例 #19
0
ファイル: ColumnReference.cs プロジェクト: nlhepler/mono
		public DataRow GetReferencedRow (DataRow row)
		{
			// Verify the column reference is valid 
			GetColumn (row);

			switch (refTable) {
			case ReferencedTable.Self:
			default:
				return row;

			case ReferencedTable.Parent:
				return row.GetParentRow (GetRelation (row));

			case ReferencedTable.Child:
				return row.GetChildRows (GetRelation (row)) [0];
			}
		}
コード例 #20
0
ファイル: PrintExcel.cs プロジェクト: thisisvoa/GranityApp2.5
 /// <summary>
 /// 绑定字段单元格数值
 /// </summary>
 /// <param name="xeField">单元格数据节点</param>
 /// <param name="dataRow">绑定行</param>
 /// <returns>已经绑定返回true</returns>
 private bool BindData(XmlElement xeField, DataRow dataRow)
 {
     if (null == xeField || null == dataRow)
         return true;
     string  alias=xeField.GetAttribute("alias");
     string  field=xeField.GetAttribute("field");
     string  key = dataRow.Table.TableName;
     PrintInfo pinfo = null;
     if (this.printInfoList.ContainsKey(key))
         pinfo = this.printInfoList[key];
     if (null != pinfo && (alias == pinfo.AliasName || alias == key))
     {
         if (!dataRow.Table.Columns.Contains(field))
         { xeField.InnerText = ""; return true; }
         object v = dataRow[field];
         if (null == v || DBNull.Value == v)
             xeField.InnerText = "";
         if (true.Equals(v))
             xeField.InnerText = "√";
         else if (false.Equals(v))
             xeField.InnerText = "×";
         else
             xeField.InnerText = Convert.ToString(v);
         return true;
     }
     if (string.IsNullOrEmpty(alias) && dataRow.Table.Columns.Contains(field))
     {
         if (!dataRow.Table.Columns.Contains(field))
             { xeField.InnerText = ""; return true; }
         object vf = dataRow[field];
         if(null == vf || DBNull.Value == vf)
             xeField.InnerText = ""; 
         if (true.Equals(vf))
             xeField.InnerText = "√";
         else if (false.Equals(vf))
             xeField.InnerText = "×";
         else
             xeField.InnerText = Convert.ToString(vf);
         return true;
     }
     foreach (DataRelation r in dataRow.Table.ParentRelations)
         if (this.BindData(xeField, dataRow.GetParentRow(r)))
             return true;
     return false;
 }