我将尝试让它变得非常短暂和甜蜜。我已经看到如何使用datagridview执行此操作,但我似乎无法使用普通的数据网格找到它。我有一个SelectedCellsChanged事件触发我要在所选行的列中获取字段。因此,当他们选择一个enite行时,我想拉动truckercode字段,这样我就可以在该行的truckercode单元格上进行SQL查询。我没有为我的datagrid做绑定。我填写数据网格的代码是
using (SqlConnection connection = new SqlConnection("server=Server; database=db; user id=user; password=user"))
{
connection.Open();
using (SqlCommand command = new SqlCommand("SELECT * FROM SOMETABLE JOIN OTHERTABLE ON SOMETABLE.TRUCKERCODE = OTHERTABLE.TRUCKERCODE WHERE SOMETABLE.ACTIVE = 1 AND OTHERTABLE.ACTIVE = 1", connection))
{
SqlDataAdapter reader = new SqlDataAdapter(command);
DataSet dataSet = new DataSet();
reader.Fill(dataSet);
FirstGrid.ItemsSource = dataSet.Tables[0].DefaultView;
}
connection.Close();
connection.Dispose();
}
我认为基于DataGrid Get Selected我认为我的代码应该与
类似private void FirstGrid_SelectedCellsChanged(object sender, SelectedCellsChangedEventArgs e)
{
DataGrid grid = sender as DataGrid;
DataRowView row = grid.SelectedItems as DataRowView;
MessageBox.Show("" + grid.SelectedItems.Count);
if (grid.SelectedItems.Count > 0)
{
MessageBox.Show(row["TruckerCode"].ToString());
}
}
但我得到一个超出范围异常的参数。
另一个有用的帖子是Looping Through A DataView
答案 0 :(得分:3)
我解决了自己的问题。我希望将来读取这个想要从整个选定行中的选定列中获取值的任何人都会使用它。此示例将打印每个单元格,无论它们选择了多少行。
var grid = FirstGrid.SelectedItems;
foreach(DataRowView row in grid)
{
if (grid.Count == 1)
{
MessageBox.Show(row["NameOfTheColumn"].ToString());
}
}
如果添加grid.Count == 1,它会阻止多行触发您的代码。所以你在DataRowView中只有一行,否则你可能有多个DataRowViews。
答案 1 :(得分:2)
您可以在dataGrid中定义CellClick处理程序
<DataGrid x:Name="dataGrid1" HorizontalAlignment="Left" Margin="235,12,0,0" VerticalAlignment="Top" Height="218" Width="501"
AutoGenerateColumns="True" ItemsSource="{Binding}">
<DataGrid.CellStyle>
<Style TargetType="{x:Type DataGridCell}">
<EventSetter Event="GotFocus" Handler="CellClick"/>
</Style>
</DataGrid.CellStyle>
</DataGrid>
一旦用户点击dataGrid中的单元格,就会在后台类中触发以下方法。 &#39;指数&#39;是所选单元格包含的值:
void CellClick(object sender, RoutedEventArgs e)
{
DataGridCell cell = sender as DataGridCell;
string index = cell.Column.DisplayIndex.ToString();
}