首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >防止C1TrueDBGrid中的重复条目

防止C1TrueDBGrid中的重复条目
EN

Stack Overflow用户
提问于 2015-11-07 10:34:50
回答 1查看 495关注 0票数 0

我正在使用我的C# Windows应用程序,这是我第一次使用tdbgrid(component1)。我希望防止用户在用数据库验证后输入重复的值。

下面是我在(BeforeColUpdate)事件中使用的代码:

代码语言:javascript
复制
bool ExitValue = false;
private void C1TrueDBGrid_BeforeColUpdate(object sender, C1.Win.C1TrueDBGrid.BeforeColUpdateEventArgs e)
{
    if (e.Column.Name == "Groups Code")
    {
        for (int currentRow = 0; currentRow < this.C1TrueDBGrid.Rows.Count - 1;currentRow++)
        {
            string rowToCompare = this.C1TrueDBGrid.Splits[0].DisplayColumns[C1TrueDBGrid.Col].DataColumn.CellValue(currentRow).ToString();
            for (int otherRow = currentRow+1 ; otherRow < this.C1TrueDBGrid.Rows.Count; otherRow++)
            { 
                bool DuplicatedRow = true;
                string Row = this.C1TrueDBGrid.Splits[0].DisplayColumns[C1TrueDBGrid.Col].DataColumn.CellValue(otherRow).ToString();
                if (Row!=rowToCompare)
                {
                    ExitValue = false;
                    break;
                }
                if (DuplicatedRow)
                {
                    C1TrueDBGrid.Splits[0].DisplayColumns[tgdGroupsUsers.Col].DataColumn.Value = DBNull.Value;
                    MessageBox.Show("Sorry: but this item(s) is already Exists  ", "Error Info", MessageBoxButtons.OK, MessageBoxIcon.Information);
                    ExitValue = true;
                    e.Cancel = true;
                }
            }
        }         
    }
    else
    {
        //Clear Fields
        C1TrueDBGrid.Splits[0].DisplayColumns[C1TrueDBGrid.Col].DataColumn.Value = null;
        e.Cancel = true;
    }
}

如果没有重复,下面是我在(AfterColUpdate)事件中使用的代码:

代码语言:javascript
复制
private void C1TrueDBGrid_AfterColUpdate(object sender, C1.Win.C1TrueDBGrid.ColEventArgs e)
{
    if (!ExitValue)
    {
        int indexRow = this.C1TrueDBGrid.RowBookmark(this.C1TrueDBGrid.Row);
        this.C1TrueDBGrid[indexRow, 0] = CSystemUsers.GroupsCode;
        this.C1TrueDBGrid[indexRow, 0] = CSystemUsers.EngName;
    }
}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-11-11 00:27:35

一个回答我的问题:

代码语言:javascript
复制
private void c1TrueDBGrid1_BeforeColUpdate(object sender, C1.Win.C1TrueDBGrid.BeforeColUpdateEventArgs e)
{
    if (e.ColIndex == 1)
    {
       for (int i = 0; i < c1TrueDBGrid1.RowCount; i++)
       {
        if (c1TrueDBGrid1.Editor.Text == c1TrueDBGrid1[i, e.ColIndex].ToString())
        {
            MessageBox.Show("Sorry: but this item(s) already Exists", "Error Info", MessageBoxButtons.OK, MessageBoxIcon.Information);
            e.Cancel = true;
        }
    }
 }
}

链接:http://our.componentone.com/groups/topic/how-do-i-prevent-duplicate-entries-in-c1truedbgrid/希望这对将来的其他人有所帮助:

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

https://stackoverflow.com/questions/33581699

复制
相关文章

相似问题

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