首页 > 解决方案 > 直接在 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代码listVeiwDataGrid

            <!--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>

标签: c#sqlwpfdatagrid

解决方案


为方便起见,您可以使用一个DataAdapter可以设置 SELECT、INSERT、UPDATE、DELETE 命令的位置。

因此,在DataAdapter填充您的DataSet/DataTable而不是直接使用命令之后,当您只调用 DataAdapter 的方法时,它将能够自动检测更改的条目更改并使用适当的方法(INSERT/UPDATE/DELETE)Update

DataAdapterFill方法,使用“SELECT”命令和Update基于RowStateDataRow 的属性使用插入/更新/删除的命令。所以当你删除/添加/修改行时,它只是改变它的状态。行的状态将以​​某种方式“更改”,直到您AcceptChanges-实际上是哪种Update方法。DataAdapter例如,您使用 DataAdapter 填充了一些数据表,然后删除了一些 DataRow - 该行仍然存在于 DataTable 中,但处于“已删除”状态。现在,当您使用刚刚修改的 DataTable 参数执行数据适配器的“更新”方法时 - DataAdapter 会查找以某种方式修改的行,并为这些行执行适当的 SQL 命令(在本例中为 DeleteCommand)。

要使用所有命令,您必须设置适当的属性SqlDataAdapter

  • UpdateCommand
  • InsertCommand
  • DeleteCommand

推荐阅读