需要解决一个小问题:
使用控件DevExpress.XtraGrid.GridControl和DevExpress.XtraGrid.Views.Grid.GridView
从数据库中读出一部原始分数据到dataTable,将之绑定到gridControl,要求不能修改和删除dataTable中的原有数据,但可以添加数据(包括可以修改和删除“用户所添加的数据”,但不能动原始数据)
不想搞得太复杂(譬如说每次得到输入焦点时判断都要判断是否是原始数据这样的方法),想通过设置行只读等简单的办法解决。是否可以实现?虚心学习。抱歉分数不高,谢谢大家的无私帮助。
使用控件DevExpress.XtraGrid.GridControl和DevExpress.XtraGrid.Views.Grid.GridView
从数据库中读出一部原始分数据到dataTable,将之绑定到gridControl,要求不能修改和删除dataTable中的原有数据,但可以添加数据(包括可以修改和删除“用户所添加的数据”,但不能动原始数据)
不想搞得太复杂(譬如说每次得到输入焦点时判断都要判断是否是原始数据这样的方法),想通过设置行只读等简单的办法解决。是否可以实现?虚心学习。抱歉分数不高,谢谢大家的无私帮助。
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Text;
using System.Windows.Forms;namespace WindowsApplication7
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
} private void gridControl1_Click(object sender, EventArgs e)
{ }
private DataTable CreateDataTable()
{
DataTable dt = new DataTable();
//如果是从数据库中的原始数据,就把设为:IsOriginal=true;
DataColumn dc = new DataColumn("IsOriginal", typeof(bool));
dt.Columns.Add(dc);
bindingSource1.DataSource = dt;
gridControl1.DataSource = bindingSource1;
gridView1.BestFitColumns(); }
private void Form1_Load(object sender, EventArgs e)
{
CreateDataTable();
} private void gridView1_CellValueChanging(object sender, DevExpress.XtraGrid.Views.Base.CellValueChangedEventArgs e)
{
DataRow dRow = gridView1.GetDataRow(gridView1.FocusedRowHandle);
if (dRow != null)
{
if (Convert.ToBoolean(dRow["IsOriginal"]) == true)
{
MessageBox.Show("数据库中的原始数据禁止修改");
bindingSource1.CancelEdit();
gridView1.RefreshData();
}
} }
}
}
谢两位,散分。
二群:90957405 状态:已满
三群:88170049 状态:热招