Datagridview 清空问题

智者潜行 2008-12-03 11:59:36
是form
我用条件查询数据,得到的数据绑定到DatagridView,比如条件有,1,2,3,我选第1次时,得到条件一的数据,但是我按条件2时(已经按了条件1), 就会得到条件1和条件2的数据?意思就是,前一个的条件会加上后一个.是不是Dataset的问题,是不是有缓冲的,但如果我在后面加上ds.clear(),就会一条数据一得不到。

DataSet ds=user.BindCall(CamCode, AssUser,b);
dgvUserInfo.DataSource = ds.Tables[0];
...全文
389 20 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
20 条回复
切换为时间正序
请发表友善的回复…
发表回复
QQQQAnnie 2008-12-03
  • 打赏
  • 举报
回复
重新绑定一下,试试
lxl_sports 2008-12-03
  • 打赏
  • 举报
回复
2楼的正确 。。。。
智者潜行 2008-12-03
  • 打赏
  • 举报
回复
dgvUserInfo.DataBind()
没有这个方法.我用的是form来的,应该程序..

[Quote=引用 2 楼 iamltlb 的回复:]
每次都要重新绑定
DataSet ds=user.BindCall(CamCode, AssUser,b);
dgvUserInfo.DataSource = ds.Tables[0];
dgvUserInfo.DataBind();
[/Quote]
mykelly6 2008-12-03
  • 打赏
  • 举报
回复

DataView view = new DataView(ds.Tables["xxx"]);
view.RowFilter = "过滤条件";
DataTable table = view.ToTable("tablename");

可以把ds.Tables["xxx"]作为数据源,然后每次条件变化就过滤一下,把过滤得到的table再设给Datagridview
wangping_li 2008-12-03
  • 打赏
  • 举报
回复
[Quote=引用楼主 lfoy112 的帖子:]
是form
我用条件查询数据,得到的数据绑定到DatagridView,比如条件有,1,2,3,我选第1次时,得到条件一的数据,但是我按条件2时(已经按了条件1), 就会得到条件1和条件2的数据?意思就是,前一个的条件会加上后一个.是不是Dataset的问题,是不是有缓冲的,但如果我在后面加上ds.clear(),就会一条数据一得不到。

DataSet ds=user.BindCall(CamCode, AssUser,b);
dgvUserInfo.DataSource = ds.Tables[0];
[/Quote]
你这个只是设置数据据源而已,并没有绑定
后面加一个dgvUserInfo.DataBind();
skeljy 2008-12-03
  • 打赏
  • 举报
回复
恩!每次读取数据的时候绑定 就不会出现LZ所说的情况了!
gsmlove 2008-12-03
  • 打赏
  • 举报
回复
mark
Old_Mouse 2008-12-03
  • 打赏
  • 举报
回复
每次查询重新帮顶。
LeayAo 2008-12-03
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 iamltlb 的回复:]
每次都要重新绑定
DataSet ds=user.BindCall(CamCode, AssUser,b);
dgvUserInfo.DataSource = ds.Tables[0];
dgvUserInfo.DataBind();
[/Quote]
这个是正解哦
liningln0 2008-12-03
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 iamltlb 的回复:]
每次都要重新绑定
DataSet ds=user.BindCall(CamCode, AssUser,b);
dgvUserInfo.DataSource = ds.Tables[0];
dgvUserInfo.DataBind();
[/Quote]

正确
iamltlb 2008-12-03
  • 打赏
  • 举报
回复
每次都要重新绑定
DataSet ds=user.BindCall(CamCode, AssUser,b);
dgvUserInfo.DataSource = ds.Tables[0];
dgvUserInfo.DataBind();
长沙三毛 2008-12-03
  • 打赏
  • 举报
回复
使用BindingSource的Filter,然后DataGridView绑到BindingSource,看看
智者潜行 2008-12-03
  • 打赏
  • 举报
回复
原来是粗心的问题,可以了.谢谢,大家,给分.
智者潜行 2008-12-03
  • 打赏
  • 举报
回复
我知道问题在哪了,原来是我在CheckBox的时候,条件选错了,

if (chkOustanding.Checked == true)
{
Status += "0,";
}
if (chkSubmitButOutstanding.Checked == true)
{
Status += "2,";
}
if (chkConsiderSing.Checked == true)
{
Status += "4,";
}

if (chkOustanding.Checked == true || chkSubmitButOutstanding.Checked == true || chkConsiderSing.Checked == true)
{
string b = Status.Remove(Status.Length - 1, 1);
string a = textBox1.Text.Trim().ToString();
user.getCall(dgvUserInfo, CamCode, AssUser, a);

}

chkSubmitButOutstanding.Checked == true这里有问题..那应该是怎么样判断是勾上了呢?
智者潜行 2008-12-03
  • 打赏
  • 举报
回复

public DataSet BindCall(string CamCode, string AssUser, string CaseStatus)
{
SqlParameter[] Params = new SqlParameter[3];
Params[0] = db.MakeInParam("@Cam_code", SqlDbType.VarChar, 50, CamCode);
Params[1] = db.MakeInParam("@Ass_User", SqlDbType.VarChar, 50, AssUser);
Params[2] = db.MakeInParam("@Case_status", SqlDbType.VarChar, 50, CaseStatus);
return SqlHelper.ExecuteDataset(db.ConnectionString, CommandType.StoredProcedure, "SP_CallQueryList", Params);
}

DataSet ds =user.BindCall(CamCode, AssUser,b);
dgvUserInfo.DataSource = ds.Tables[0];



[Quote=引用 17 楼 wangping_li 的回复:]
引用 16 楼 lfoy112 的回复:
还是一样的问题..会不会是要把datagridview清除掉? 引用 15 楼 birdlonger 的回复:
DataSet ds = new DataSet();
ds.Clear();
ds= user.BindCall(CamCode, AssUser,b);
dgvUserInfo.DataSource = ds.Tables[0];
换为这样你试下!

这和datagridview没关系
dgvUserInfo.DataSource = ds.Tables[0]; 你在这里已经重新绑定了数据源
你这时的ds.Tables[0].Count肯定是2,要么的话不会出…
[/Quote]
wangping_li 2008-12-03
  • 打赏
  • 举报
回复
[Quote=引用 16 楼 lfoy112 的回复:]
还是一样的问题..会不会是要把datagridview清除掉? 引用 15 楼 birdlonger 的回复:
DataSet ds = new DataSet();
ds.Clear();
ds= user.BindCall(CamCode, AssUser,b);
dgvUserInfo.DataSource = ds.Tables[0];
换为这样你试下!
[/Quote]
这和datagridview没关系
dgvUserInfo.DataSource = ds.Tables[0]; 你在这里已经重新绑定了数据源
你这时的ds.Tables[0].Count肯定是2,要么的话不会出现两条的
DataSet重新赋值时也不会出现你这种情况,已经后面查询又实例化一个新的对象了
你跟踪到user.BindCall(CamCode, AssUser,b);方法里面去看看到底哪里出错了
或者把这个方法的代码发出来
智者潜行 2008-12-03
  • 打赏
  • 举报
回复
还是一样的问题..会不会是要把datagridview清除掉?
[Quote=引用 15 楼 birdlonger 的回复:]
DataSet ds = new DataSet();
ds.Clear();
ds= user.BindCall(CamCode, AssUser,b);
dgvUserInfo.DataSource = ds.Tables[0];
换为这样你试下!
[/Quote]
birdlonger 2008-12-03
  • 打赏
  • 举报
回复
DataSet ds = new DataSet();
ds.Clear();
ds= user.BindCall(CamCode, AssUser,b);
dgvUserInfo.DataSource = ds.Tables[0];
换为这样你试下!
wangping_li 2008-12-03
  • 打赏
  • 举报
回复
是From的话直接设DataSource就可以了
DataSet ds=user.BindCall(CamCode, AssUser,b);
dgvUserInfo.DataSource = ds.Tables[0];

你上面这样写的话等于重新查了一遍,再绑定的,因为你每次选择的是一个数这了,所以传进去的也是一个条件
出来的记录肯定是一条了
你可以把之前的的DataTable保存起来,然后新查出来的记录添加到前面保存的DataTable中
最简单的就是你把先的查询条件保存起来,然后根据条件or来查
再绑定就对了
qiqundelang 2008-12-03
  • 打赏
  • 举报
回复
每次查询重新帮顶。

111,097

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • AIGC Browser
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧