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];
...全文
385 20 打赏 收藏 转发到动态 举报
写回复
用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
  • 打赏
  • 举报
回复
每次查询重新帮顶。
vs2015+数据库,需要建的数据表如下: 1. “考试成绩管理系统用户登录”功能 具体要求: (1) 按照图示排列相应的控件,控件名称自定义,其中,界面中的图片可以不加; (2) 当输入正确的用户名和密码时,登录到主系统,如图所示,并且用户名或密码输入不正确时系统有所提示;当单击【取消】按钮时,用户名和密码被清空; (3) 程序中用到的数据库名为SCOREINFO,数据表名为userinfo,数据表结构如下图所示: (4) 数据表中的用户名和密码如下图。 2. 点击主窗体的“密码修改”菜单,完成“密码修改”功能,程序运行如下图所示: 具体要求: (1)此题必须使用数据库连接完成,原始密码必须为数据表里原有的数据,不使用数据库完成的为0分。 (2)需要建立数据库SCOREINFO及数据表userinfo,表的结构及数据第一部分的内容: (3)要有“原始密码输入错误”、“原始密码不能为空”及“两次输入密码不一致”的错误提示; (4)当单击【保存】按钮,新密码被更新到数据表中,不能更新的为0分; (5)单击【关闭】按钮,窗口关闭。 (6)3个Label;3个TextBox;2个Button 3. 完成“成绩查询”功能,程序运行如下图所示: 具体要求: (1) 按照图示排列相应的控件,界面下方是DataGridView控件; (2)程序用到的数据库名为SCOREINFO,数据表名为score,表结构如下: (3)完成的MainForm_Load事件处理程序:当加载窗体时,直接在窗体的dataGridView1控件中显示数据表的所有记录; (4)可以设查询条件:首先在组合框comboBox1中选择查询条件,并在textBox1中输入条件值(可以模糊查询,如按照姓名查询时,输入“王”,可以查所有姓王的同学的成绩),单击查询将结果显示在dataGridView1控件中。 (5)所需控件及属性:1个GroupBox,1个Label,Text为选择查询条件;1个ComboBox(Items:学号、姓名);1个TextBox;1个Button,Text为查询;1个DataGridView 4. 完成“课程信息修改”功能,程序运行如下图所示: 具体要求: (1)按照图示排列相应的控件,控件名称自定义,其中,程序刚开始运行时,“学分”和“课程编码”的文本框是只读的; (2)在数据库名为SCOREINFO中,创建数据表名为course,表结构如下: (3)当单击【查询】时,直接在窗体的dataGridView2控件中显示数据表的所有记录; (4)当选中DataGridView控件中的某一行记录时(DataGridView控件的Mouse_Click事件),“课程名字”、“学分”、“课程代码”文本框中分别显示该项对应的课程信息; (5)当选中某一行记录并单击【编辑】按钮时,【编辑】按钮变为【保存修改】,同时“学分”和“课程编码”的文本框恢复正常(ReadOnly属性为false);在文本框中修改相应的信息后单击【保存修改】,将修改后的数据更新到数据表中。 (6)所需控件及属性:1个GroupBox,3个Label;3个TextBox(textBox2属性ReadOnly为True,textBox3属性ReadOnly为True);2个Button;1个DataGridView 5. 完成“课程信息删除”功能,程序运行如下图所示: 具体要求: (1)按照图示排列相应的控件,控件名称自定义,其中,程序刚开始运行时,“学分”和“课程编码”的文本框是只读的; (2)数据表名为course,表结构同第4部分: (3)当单击【查询】时,直接在窗体的dataGridView控件中显示数据表的所有记录; (4)当选中DataGridView控件中的某一行记录时,“课程名字”、“学分”、“课程代码”文本框中分别显示该项对应的课程信息; (5)当选中某一行记录并单击【删除】按钮时,则该行从数据表中删除。 (6)所需控件:3个Label;3个TextBox(textBox2属性ReadOnly为True,textBox3属性ReadOnly为True);2个Button;1个DataGridView 6. 完成“课程信息添加”功能,程序运行如下图所示: 具体要求: (1)按照图示排列相应的控件,控件名称自定义; (2)程序用到的数据库和数据表名为course,表结构如下同第四部分: (3)当单击【查询】时,直接在窗体的dataGridView1控件中显示数据表的所有记 (4)当选中DataGridView控件中的某一行记录时,“课程名字”、“学分”、“课程代码”文本框中分别显示该项对应的课程信息; (5)当单击【添加】按钮时,在文本框中添加新的内容并将新内容添加到数据表中,并且在DataGridView控件中显示出新的课程信息 (6)所需控件:3个Label;3个TextBox;2个Button;1个DataGridView

110,552

社区成员

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

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

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