[英]How to fill a WPF Datagrid but not directly from the DB using C#
我一直在这个墙上撞墙一段时间。 我正在尝试使用C#.net从mysql数据库填充WPF数据网格。 问题是我需要在将数据粘贴到数据网格之前修改数据,因为数据格式不正确。 我在搜索时可以找到的唯一示例是如何自动将查询中的数据直接粘贴到数据库中。
这是我目前的mysql表格。
1 0456 clockin 5/14/2013 8:36:26 AM
2 0456 breakout 5/14/2013 8:36:39 AM
3 0456 breakin 5/14/2013 8:36:40 AM
4 0456 clockout 5/14/2013 8:36:41 AM
5 0456 clockin 5/14/2013 8:37:14 AM
6 0456 breakout 5/14/2013 8:50:27 AM
7 0456 breakin 5/14/2013 8:50:34 AM
现在我需要用给定的用户ID(0456)取出本周(5月12日至5月18日)的所有拳击。 然后我需要将这些值粘贴到一周中七天设置的数据网格中。 因此,在每一天,它会列出所有的冲击(clockin,breakout等)及其相关时间。
编辑:tnw要求代码。 这是我的datagrid的XML:
<DataGrid AutoGenerateColumns="False" Height="253" HorizontalAlignment="Center" Margin="219,208,0,0" Name="weekHours" VerticalAlignment="Top" Width="556" HorizontalContentAlignment="Center" CanUserAddRows="True" CanUserReorderColumns="False" CanUserResizeColumns="False" CanUserResizeRows="False" CanUserSortColumns="False" Focusable="False">
<DataGrid.Columns>
<DataGridTextColumn Header="Action" Width="100"/>
<DataGridTextColumn Header="Sun" Width="65"/>
<DataGridTextColumn Header="Mon" Width="65"/>
<DataGridTextColumn Header="Tue" Width="65"/>
<DataGridTextColumn Header="Wed" Width="65"/>
<DataGridTextColumn Header="Thu" Width="65"/>
<DataGridTextColumn Header="Fri" Width="65"/>
<DataGridTextColumn Header="Sat" Width="65"/>
</DataGrid.Columns>
</DataGrid>
然后对于后面的代码,这是我可以找到的关于如何填充Datagrid的全部内容。
public void FillDataGrid(String query, DataGrid dg)
{
//Open connection
if (this.OpenConnection() == true)
{
//Create Command
MySqlCommand cmd = new MySqlCommand(query, connection);
DataTable dt = new DataTable();
MySqlDataAdapter da = new MySqlDataAdapter(cmd);
da.Fill(dt);
dg.DataContext = dt;
}
}
任何帮助将非常感激。 我是C#和.net的新手。 也许我甚至不应该使用数据网格。 谢谢迈克
您可以使用绑定到DataGrid
的视图模型。 从数据库加载数据后,遍历记录并创建视图模型。 以下代码段显示了解决问题的方法:
MyViewModel.cs:
public class MyViewModel
{
public DateTime Date { get; set; }
public int Punches { get; set; }
public int UserId { get; set; }
}
在这里,您将数据绑定到DataGrid:
var viewModels = new List<MyViewModel>();
foreach(var item in dt.Rows)
{
var vm = new MyViewModel();
vm.UserId = item["UserId"];
vm.Punches = item["Punches"];
vm.Date = DateTime.Parse(item["Date"]);
//....
viewModels.Add(vm);
}
dg.DataContext = viewModels;
如果您使用WPF并且可能使用MVVM,这是一种常见模式。 视图模型包含实际数据,但可以选择进行修改以便在视图中更好地显示(这里是您的DataGrid
)。 如果您进行一些研究,您会注意到,大多数视图模型都会实现INotifyPropertyChanged
以进行更改跟踪。 如果您想在用户修改DataGrid
中的内容时做出反应,您的视图模型也可以实现此接口。
你可以使用ListView - GridView
<ListView ItemsSource="{Binding YourData}">
<ListView.View>
<GridView>
<!-- The columns here -->
</GridView>
</ListView.View>
</ListView>
在你的代码中,你将创建一个属性(或你喜欢这样做),它是IEnumerable
,你可以用它来数据绑定。 否则,您可以设置网格的“ Datasource
属性。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.