c# - 直接在 DataGrid 中插入、更新和删除行并将更改保存在数据库中
问题描述
我有一个ListView
来自我的 SQL Server 数据库的表列表。Selected
我的列表视图项目也有一个事件,它DataGrid
用数据库中的表填充我。
我希望用户能够INSERT, UPDATE, & DELETE
在所选表中进行行并将这些更改保存在数据库中。
DataGrid
这是我在选择项目时填充的代码ListView
。我删除了一些,以免太长:
public partial class TableManagement : UserControl
{
public TableManagement()
{
InitializeComponent();
}
private void CustomerContact_Selected(object sender, RoutedEventArgs e)
{
try
{
string connectionString = ("Data Source=WINDOWS-B1AT5HC\\SQLEXPRESS;Initial Catalog=CustomerRelations;Integrated Security=True;");
DataTable dt = new DataTable();
SqlConnection connection = new SqlConnection(connectionString);
SqlDataAdapter cmd = new SqlDataAdapter("SELECT [TXT_CUST_CNT], [Inactive] FROM [hb_CustCntct] ", connection);
cmd.Fill(dt);
dt.AcceptChanges();
dt_TableManagement.DataContext = dt;
dt_TableManagement.SelectedIndex = 0;
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
}
}
这是我的XMAL
代码listVeiw
DataGrid
<!--Grid 1-->
<Grid x:Name="Grid1" Grid.Row="1" Grid.Column="0" Margin="15">
<ListView>
<ListViewItem x:Name="CustomerContact" Content="Customer Contact" Selected="CustomerContact_Selected"/>
<ListViewItem x:Name="CsrNames" Content="Customer Service Representative Names" Selected="CsrNames_Selected"/>
<ListViewItem x:Name="DisputeClassification" Content="Dispute Classification" Selected="DisputeClassification_Selected"/>
<ListViewItem x:Name="DisputeStatus" Content="Dispute Status" Selected="DisputeStatus_Selected"/>
<ListViewItem x:Name="FinancialAdjustment" Content="Financial Adjustment" Selected="FinancialAdjustment_Selected"/>
<ListViewItem x:Name="InitialCallAnalysis" Content="Initial Call Analysis" Selected="InitialCallAnalysis_Selected"/>
<ListViewItem x:Name="InitialCallReason" Content="Initial Call Reason" Selected="InitialCallReason_Selected"/>
<ListViewItem x:Name="MeterIssue" Content="Meter Issue" Selected="MeterIssue_Selected"/>
<ListViewItem x:Name="OpenInError" Content="Open In Error" Selected="OpenInError_Selected"/>
<ListViewItem x:Name="PrimaryCause" Content="Primary Cause" Selected="PrimaryCause_Selected"/>
<ListViewItem x:Name="RequestedWork" Content="Requested Work" Selected="RequestedWork_Selected"/>
<ListViewItem x:Name="RevenueClass" Content="Revenue Class" Selected="RevenueClass_Selected"/>
<ListViewItem x:Name="ServiceOrderDetails" Content="Service Order Details" Selected="ServiceOrderDetails_Selected"/>
<ListViewItem x:Name="ServiceOrderType" Content="Service Order Type" Selected="ServiceOrderType_Selected"/>
<ListViewItem x:Name="ServiceOrderAdjustment" Content="Service Order Adjusted" Selected="ServiceOrderAdjustment_Selected"/>
<ListViewItem x:Name="UnderlyingCause" Content="Underlying Cause" Selected="UnderlyingCause_Selected"/>
<ListViewItem x:Name="UtilityReportType" Content="Utility Report Type" Selected="UtilityReportType_Selected"/>
<ListViewItem x:Name="WFMIssuedBy" Content="WFM Issued By" Selected="WFMIssuedBy_Selected"/>
</ListView>
</Grid>
<!--Grid 2-->
<Grid x:Name="Grid2" Grid.Row="1" Grid.Column="2" Margin="15">
<DataGrid x:Name="dt_TableManagement"
materialDesign:ListBoxAssist.IsToggle="True"
Background="White"
EnableColumnVirtualization="True"
EnableRowVirtualization="True"
ItemsSource="{Binding}">
</DataGrid>
</Grid>
解决方案
为方便起见,您可以使用一个DataAdapter
可以设置 SELECT、INSERT、UPDATE、DELETE 命令的位置。
因此,在DataAdapter
填充您的DataSet
/DataTable
而不是直接使用命令之后,当您只调用 DataAdapter 的方法时,它将能够自动检测更改的条目更改并使用适当的方法(INSERT/UPDATE/DELETE)Update
。
DataAdapter
有Fill
方法,使用“SELECT”命令和Update
基于RowState
DataRow 的属性使用插入/更新/删除的命令。所以当你删除/添加/修改行时,它只是改变它的状态。行的状态将以某种方式“更改”,直到您AcceptChanges
-实际上是哪种Update
方法。DataAdapter
例如,您使用 DataAdapter 填充了一些数据表,然后删除了一些 DataRow - 该行仍然存在于 DataTable 中,但处于“已删除”状态。现在,当您使用刚刚修改的 DataTable 参数执行数据适配器的“更新”方法时 - DataAdapter 会查找以某种方式修改的行,并为这些行执行适当的 SQL 命令(在本例中为 DeleteCommand)。
要使用所有命令,您必须设置适当的属性SqlDataAdapter
UpdateCommand
InsertCommand
DeleteCommand
推荐阅读
- matrix - 是否可以从 ndarray 获得不连续的切片?
- jquery - 在 GridMvc 中有日期范围过滤器
- android - Asynctask 崩溃 ViewPager RecyclerView (Android)
- mysql - MariaDB:预定事件触发两次?
- amazon-web-services - 无法创建 AWS EC2 实例 sbin/plymouthd:没有这样的文件
- javascript - Math.floor 为什么这个四舍五入不正确?
- android - android导航清除任务
- jpa - 域被驱逐到 JAR 后 JPA @Inheritance 策略失败
- c# - 从哪里开始在 WPF 表单上生成按钮
- spring - 邮递员:创建复杂的 MULTIPART_FORM_DATA 请求