首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >提交更改c# linq后DataGridView未更新

提交更改c# linq后DataGridView未更新
EN

Stack Overflow用户
提问于 2018-05-30 01:48:59
回答 2查看 421关注 0票数 0

我有一个简单的客户注册表。我在数据网格视图旁边放置了一些文本框,以便添加和更新用户。它工作得很好,现在也是。

最近,我为客户端定义添加了一个新的windows窗体,这样当双击一行时,就会出现一个带有必填字段的窗体,该窗体显示客户信息并允许您更改它们。单击"OK“按钮将保存对SQL数据库的更改。

使用网格视图旁边的字段,当我更新用户信息时,网格视图会立即更新并显示数据,但是当使用新表单更新数据时,即使我再次双击该行,更新也不会显示在网格视图中。当我关闭应用程序并再次运行它时,我将看到更新后的数据。

我已经为main form添加了一个激活事件,以便通过再次从数据库中选择数据来更新网格视图,但没有成功。这是我用来从侧面板更新的代码:

代码语言:javascript
复制
private void btnUpdate_Click(object sender, EventArgs e)
{
    if (btnUpdate.Text == "Update")
    {
        txtUsername.Text = ClientsGridView.CurrentRow.Cells["Username"].Value.ToString();
        txtPassword.Text = ClientsGridView.CurrentRow.Cells["Password"].Value.ToString();
        txtUID.Text = ClientsGridView.CurrentRow.Cells["UID"].Value.ToString();
        txtName.Text = ClientsGridView.CurrentRow.Cells["Name"].Value.ToString();
        chkIsActive.Checked = (bool)ClientsGridView.CurrentRow.Cells["IsActive"].Value;
        chkItemListAccess.Checked = (bool)ClientsGridView.CurrentRow.Cells["ItemListAccess"].Value;
        chkMaterialSumAccess.Checked = (bool)ClientsGridView.CurrentRow.Cells["MaterialSumAccess"].Value;
        chkPartListAccess.Checked = (bool)ClientsGridView.CurrentRow.Cells["PartListAccess"].Value;
        chkPriceListAccess.Checked = (bool)ClientsGridView.CurrentRow.Cells["PriceListAccess"].Value;

        btnUpdate.Text = "Apply Update";
        btnSubmit.Enabled = false;
        txtUsername.ReadOnly = true;
    }
    else if (btnUpdate.Text == "Apply Update")
    {
        if (ClientFormValidation())
        {
            int id = Convert.ToInt32(ClientsGridView.CurrentRow.Cells["ID"].Value.ToString());
            var SelectedUser = from Client in ClientsContext.Clients
                               where Client.ID == id
                               select Client;
            if (SelectedUser.Count() == 1)
            {
                Client UpdatingClient = SelectedUser.Single();
                UpdatingClient.Password = txtPassword.Text.Trim();
                UpdatingClient.UID = txtUID.Text.Trim();
                UpdatingClient.Name = txtName.Text.Trim();
                UpdatingClient.IsActive = chkIsActive.Checked;
                UpdatingClient.ItemListAccess = chkItemListAccess.Checked;
                UpdatingClient.MaterialSumAccess = chkMaterialSumAccess.Checked;
                UpdatingClient.PartListAccess = chkPartListAccess.Checked;
                UpdatingClient.PriceListAccess = chkPriceListAccess.Checked;

                ClientsContext.SubmitChanges();

            }
            ShowAll();
            ClearClientForm();
            btnUpdate.Text = "Update";
            btnSubmit.Enabled = true;
            txtUsername.ReadOnly = false;
        }


    }
}

这是用于客户端定义的表单:

代码语言:javascript
复制
private void btnOK_Click(object sender, EventArgs e)
{
    if(ISnewUser)
    {
        InsertNewClient();
    }
    else if(!ISnewUser)
    {
        UpdateClient();
    }
    this.Close();
}

private void UpdateClient()
{
    if (ClientFormValidation())
    {

        var SelectedUser = from Client in ClientsContext.Clients
                           where Client.ID == id
                           select Client;
        if (SelectedUser.Count() == 1)
        {
            Client UpdatingClient = SelectedUser.Single();
            UpdatingClient.Password = txtPassword.Text.Trim();
            UpdatingClient.UID = txtUID.Text.Trim();
            UpdatingClient.Name = txtName.Text.Trim();
            UpdatingClient.IsActive = chkUserActiveSatus.Checked;
            UpdatingClient.ItemListAccess = chkItemListAccess.Checked;
            UpdatingClient.MaterialSumAccess = chkMaterialSummeryAccess.Checked;
            UpdatingClient.PartListAccess = chkPartListAccess.Checked;
            UpdatingClient.PriceListAccess = chkPriceListAcess.Checked;
            ClientsContext.SubmitChanges();


        }

    }
}

谁能告诉我这段代码出了什么问题?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2018-05-30 07:19:52

我自己解决了这个问题,我在初始化客户端定义表单时传递了一个客户端对象。因此,在更新时,我使用了完全相同的对象,而不是获取其参数并从数据库中再次选择它:

代码语言:javascript
复制
public frmClientDefinition(Client thisClient=null)
        {

            InitializeComponent();
            if (thisClient!=null)
            {
                User = thisClient;
                id = thisClient.ID;
                ISnewUser = false;
                txtName.Text = thisClient.Name;
                txtUsername.Text = thisClient.Username;
                txtPassword.Text = thisClient.Password;
                txtDate.Text = thisClient.Date.ToString();
                txtUID.Text = thisClient.UID;
                chkUserActiveSatus.Checked = thisClient.IsActive;
                chkItemListAccess.Checked = thisClient.ItemListAccess;
                chkPartListAccess.Checked = thisClient.PartListAccess;
                chkMaterialSummeryAccess.Checked = thisClient.MaterialSumAccess;
                chkPriceListAcess.Checked = thisClient.PriceListAccess;
                chkFullPriceListAccess.Checked = false;
                chkOfficialRecieptAccess.Checked = false;
                chkNonOfficialRecieptAccess.Checked = false;
                chkAdvancedPriceControlsAccess.Checked = false;
                chkFullPriceListSaveAccess.Checked = false;
                chkOfficialRecieptSaveAccess.Checked = false;
                chkNonOfficialRecieptSaveAccess.Checked = false;
                txtUsername.ReadOnly = true;
            }
            txtDate.Text = DateTime.Now.ToString();
        }

为了更新这段代码:

代码语言:javascript
复制
private void UpdateClient()
        {
            if (ClientFormValidation())
            {
                    User.Password = txtPassword.Text.Trim();
                    User.UID = txtUID.Text.Trim();
                    User.Name = txtName.Text.Trim();
                    User.IsActive = chkUserActiveSatus.Checked;
                    User.ItemListAccess = chkItemListAccess.Checked;
                    User.MaterialSumAccess = chkMaterialSummeryAccess.Checked;
                    User.PartListAccess = chkPartListAccess.Checked;
                    User.PriceListAccess = chkPriceListAcess.Checked;
                    ClientsContext.SubmitChanges();
            }
        }
票数 0
EN

Stack Overflow用户

发布于 2018-05-30 02:30:24

代码语言:javascript
复制
  *var SelectedUser = from Client in ClientsContext.Clients
                                           where Client.ID == id
                                           select Client;

它是Iqueryable的,应用.ToList()来获取内存,然后修补更改。

相反,我建议,使用这个,

代码语言:javascript
复制
var SelectedUser = (from Client in ClientsContext.Clients
                                           where Client.ID == id
                                           select Client).FirstOrDefault();
if(SelectedUser!=null){
                    SelectedUser.Password = txtPassword.Text.Trim();
                    SelectedUser.UID = txtUID.Text.Trim();
                    SelectedUser.Name = txtName.Text.Trim();
                    SelectedUser.IsActive = chkUserActiveSatus.Checked;
                    SelectedUser.ItemListAccess = chkItemListAccess.Checked;
                    SelectedUser.MaterialSumAccess = chkMaterialSummeryAccess.Checked;
                    SelectedUser.PartListAccess = chkPartListAccess.Checked;
                    SelectedUser.PriceListAccess = chkPriceListAcess.Checked;
                    ClientsContext.SubmitChanges();
}
else{
//write your logic
}*

我只把异常处理留给你。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50590132

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档