gpt4 book ai didi

c# - 以数据库为源的Master-Detail View 获取详细元素个数

转载 作者:搜寻专家 更新时间:2023-10-30 23:39:10 24 4
gpt4 key购买 nike

我使用两个 DataGridView 和连接到同一数据库的 BindingSource 创建了主从 View 。数据库有两个表,我在 Microsoft tutorial 之后在它们之间建立了主从 View 。 .这是负责它的代码:

private void GetData()
{
try
{
// Specify a connection string. Replace the given value with a
// valid connection string for a Northwind SQL Server sample
// database accessible to your system.
String connectionString =
"Integrated Security=SSPI;Persist Security Info=False;" +
"Initial Catalog=Northwind;Data Source=localhost";
SqlConnection connection = new SqlConnection(connectionString);

// Create a DataSet.
DataSet data = new DataSet();
data.Locale = System.Globalization.CultureInfo.InvariantCulture;

// Add data from the Customers table to the DataSet.
SqlDataAdapter masterDataAdapter = new
SqlDataAdapter("select * from Customers", connection);
masterDataAdapter.Fill(data, "Customers");

// Add data from the Orders table to the DataSet.
SqlDataAdapter detailsDataAdapter = new
SqlDataAdapter("select * from Orders", connection);
detailsDataAdapter.Fill(data, "Orders");

// Establish a relationship between the two tables.
DataRelation relation = new DataRelation("CustomersOrders",
data.Tables["Customers"].Columns["CustomerID"],
data.Tables["Orders"].Columns["CustomerID"]);
data.Relations.Add(relation);

// Bind the master data connector to the Customers table.
masterBindingSource.DataSource = data;
masterBindingSource.DataMember = "Customers";

// Bind the details data connector to the master data connector,
// using the DataRelation name to filter the information in the
// details table based on the current row in the master table.
detailsBindingSource.DataSource = masterBindingSource;
detailsBindingSource.DataMember = "CustomersOrders";
}
catch (SqlException)
{
MessageBox.Show("To run this example, replace the value of the " +
"connectionString variable with a connection string that is " +
"valid for your system.");
}
}

而且效果很好。接下来,我向主视图添加了一个自定义列,并按照相同的教程使用此代码段来编辑主视图的外观。

// Changes how cells are displayed depending on their columns and values.
private void masterGridView_CellFormatting(object sender,
System.Windows.Forms.DataGridViewCellFormattingEventArgs e)
{
// Set the background to red for negative values in the Balance column.
if (masterGridView.Columns[e.ColumnIndex].Name.Equals("CustomColumn"))
{

e.CellStyle.BackColor = Color.Red;
e.CellStyle.SelectionBackColor = Color.DarkRed;
}
}

现在我想在选择不同的母版时获取每个详细 View 中的行数。我会将其添加到自定义列中。这就是我卡住的地方。如何从最后一个片段中的单元格格式化程序事件访问计数?我也可以访问 View 和数据源。

最佳答案

加载数据并添加自定义列后,尝试使用 DataRow.GetChildRows方法来计算详细信息 View 中的行数。这将设置初始值:

DataSet ds = this.masterBindingSource.DataSource as DataSet;
string tableName = this.masterBindingSource.DataMember;

foreach (DataGridViewRow row in this.masterDataGridView.Rows)
{
row.Cells["CustomColumn"].Value = ds.Tables[tableName].Rows[row.Index].GetChildRows(ds.Relations[0]).Length;
}

如果您将允许用户从详细信息 View 中添加/删除行,我建议首先设置以下(*):

this.masterDataGridView.AllowUserToAddRows = false;
this.detailsDataGridView.AllowUserToAddRows = false;

从那里您需要附加到详细信息 DataTable 上的 RowChangedRowDeleting 事件:

ds.Tables["Orders"].RowChanged += Details_RowChanged;
ds.Tables["Orders"].RowDeleting += Details_RowChanged;

在该事件处理程序中,我们将再次根据 GetChildRows 方法设置主行的自定义列值。特别注意事项:

  • 对于已删除的行,该计数还不会反射(reflect)删除。我们会对此负责。
  • 对于添加的行,除非您已经在添加时设置了父行,否则您需要在此处进行处理。

话虽如此:

private void Details_RowChanged(object sender, DataRowChangeEventArgs e)
{
int change = 0;
DataSet ds = this.masterBindingSource.DataSource as DataSet;

if (e.Action == DataRowAction.Add)
{
DataRow parent = null;

foreach (DataRow dr in ds.Tables["Customers"].Rows)
{
if (dr["CustomerID"].Equals(e.Row["CustomerID"]))
{
parent = dr;
break;
}
}

e.Row.SetParentRow(parent);
}
else if (e.Action == DataRowAction.Delete)
{
change = -1;
}

DataRow row = e.Row.GetParentRow(ds.Relations[0]);
int index = ds.Tables["Customers"].Rows.IndexOf(row);

this.masterDataGridView.Rows[index].Cells["CustomColumn"].Value = row.GetChildRows(ds.Relations[0]).Length + change;
}

(*) 添加行应该以编程方式完成 - DataTable.Rows.Add(params object[] values) -添加到数据绑定(bind) DataGridView 时。

关于c# - 以数据库为源的Master-Detail View 获取详细元素个数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37270397/

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