简体   繁体   English

在C#,WPF中,如何将基于sqlite数据库的datagrid中存储在数据库中的值设置/分配给复选框

[英]in c#, wpf, how do you set/assign value stored in database to a checkbox in datagrid based in sqlite database

In wpf, i have value in my sqlite database column as true for one record but it is not showing up as mark checked in datagrid column. 在wpf中,我在sqlite数据库列中的一条记录的值为true,但未在datagrid列中显示为选中的标记。 Can someone help? 有人可以帮忙吗? xaml code: XAML代码:

    <DataGrid x:Name="DG_VendorPur" AutoGenerateColumns="False" ItemsSource="{Binding VendorProducts}" Grid.Row="7" Grid.RowSpan="4" FontFamily="Franklin Gothic Medium" FontSize="18" Background="#FFEBDCEB" AlternatingRowBackground="#FFDAE7F5" SelectionMode="Single" ColumnWidth="*" Grid.Column="5" Grid.ColumnSpan="6" SelectedCellsChanged="DG_VendorPur_SelectedCellsChanged">
                    <DataGrid.Columns>
                        <DataGridCheckBoxColumn x:Name="DG_V_IsDefault" Header=" Preferred "    MinWidth="50" Width="*" Binding="{Binding Path=VP_isVendorActive, Mode=TwoWay}" SortDirection="Ascending" IsThreeState="True" />
                        <DataGridTextColumn     x:Name="DG_Vname"       Header=" Vendor Name "  MinWidth="50" Width="*" Binding="{Binding Path=VP_Vname}"       FontFamily="Calibri" />
                        <DataGridTextColumn     x:Name="DG_VItemNo"     Header=" Vendor SKU# "  MinWidth="50" Width="*" Binding="{Binding Path=VP_VendorSKU}"   FontFamily="Calibri"/>
                        <DataGridTextColumn     x:Name="DG_VCaseCost"   Header=" Case Cost "    MinWidth="50" Width="*" Binding="{Binding Path=VP_SKUcaseCost}" FontFamily="Calibri"/>
                        <DataGridTextColumn     x:Name="DG_VQtyPerCase" Header=" Qty/Case "     MinWidth="50" Width="*" Binding="{Binding Path=VP_QtyInCase}"   FontFamily="Calibri"/>
                    </DataGrid.Columns>
                </DataGrid>

xaml.cs : xaml.cs:

    sqliteCon.Open();
                string Product = TB_PscanID.Text;
                cmd.CommandText = "Select VP_Vname,VP_VendorSKU,VP_SKUcaseCost,VP_QtyInCase from VendorProducts where VP_ProductID= @WORD";
                cmd.Parameters.AddWithValue("@word", Product);
                cmd.Prepare();
                cmd.ExecuteNonQuery();
                SQLiteDataAdapter SDAdap = new SQLiteDataAdapter(cmd);
                DataTable DT = new DataTable("VendorProducts");
                SDAdap.Fill(DT);

                DG_VendorPur.ItemsSource = DT.DefaultView;
                DataRecord = DG_VendorPur.Items.Count;
                SDAdap.Update(DT);
                sqliteCon.Close();

The issue is with your query: 问题出在您的查询中:

SELECT VP_isVendorActive, /* You're missing this column */
       VP_Vname,
       VP_VendorSKU,
       VP_SKUcaseCost,
       VP_QtyInCase
FROM VendorProducts WHERE VP_ProductID= @WORD

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM