如何及时刷新DATAGRIDVIEW的数据,在线等

fangzhang1981 2010-06-02 08:32:18
我是一个C#的初学者,做了一个简单的添加程序,但是在添加完成后datagridview中不及时刷新数据,请各位高人指点一下。
下图是添加程序的界面

下图是添加完成后显示的界面

以下是点击保存按钮的源代码:
SqlConnection mySqlConnection = new SqlConnection("server=(local);database=caiwu;uid=sa;pwd=123");//建立数据库连接
mySqlConnection.Open();//打开数据库连接
SqlCommand myCommand = mySqlConnection.CreateCommand();
string sql = "insert into cw_user(username,password) values('" + username.Text.Trim() + "','" + userpass.Text.Trim() + "')";
myCommand.CommandText = sql;
SqlDataReader myDataReader = myCommand.ExecuteReader();
MessageBox.Show("操作员保存成功!!");
myDataReader.Close();
mySqlConnection.Close();
string strSql = "select username,password from cw_user";//现在的搜索条件
SqlConnection con = new SqlConnection("server=(local);database=caiwu;uid=sa;pwd=123");
SqlCommand cmd = new SqlCommand(strSql, con);
con.Open();
SqlDataReader sdr = cmd.ExecuteReader();
this.dataGridView1.DataSource = null;
this.dataGridView1.DataSource = sdr;
this.dataGridView1.Refresh();
con.Close();

请各位高手指点一下。
...全文
3691 22 打赏 收藏 转发到动态 举报
写回复
用AI写文章
22 条回复
切换为时间正序
请发表友善的回复…
发表回复
xxjltan 2012-06-08
  • 打赏
  • 举报
回复
把你这段代码封装成函数,再执行一次就可以了
string strSql = "select username,password from cw_user";//现在的搜索条件
SqlConnection con = new SqlConnection("server=(local);database=caiwu;uid=sa;pwd=123");
SqlCommand cmd = new SqlCommand(strSql, con);
con.Open();
SqlDataReader sdr = cmd.ExecuteReader();
this.dataGridView1.DataSource = null;
this.dataGridView1.DataSource = sdr;
this.dataGridView1.Refresh();
con.Close();

yp19910928 2012-06-08
  • 打赏
  • 举报
回复
看不见图片
kuailedexiaozide 2012-06-08
  • 打赏
  • 举报
回复
怎样自动刷新datagridview阿
bdyaicxy 2011-04-04
  • 打赏
  • 举报
回复
你绑定到的是sqldatareader,你应该先声明一个sqldataadapter。
SqlDataAdapter sda = new SqlDataAdapter(myCommand);
Datatable dt=new datatable();
sda.fill(dt);
this.dataGridView1.DataSource=dt;
bdyaicxy 2011-04-04
  • 打赏
  • 举报
回复
系统自动生成的方式,实际上是将dgv的数据源绑定到dataset。每次数据库中的数据改变不会改变到dataset中,而dataset的数据是使用tabledataadapter填充进去的。所以只要使用dataadapter将dataset的数据重新填充就OK了
bdyaicxy 2011-04-04
  • 打赏
  • 举报
回复
this.addressTableAdapter.Fill(this.adventureWorksDataSet.Address);
这句在你的Form1_Load里会自动添加到,直接复制就OK了
这里假定你使用的是vs的dataset,bingdingsource,tableadapter三个组合使用填充数据的方式填充到datagridview。
addressTableAdapter是tableadapter,adventureWorksDataSet是dataset,Address是其中的一个表
garfieldzf 2010-08-02
  • 打赏
  • 举报
回复
添加完成后重新绑定一下,

或者用timer实时刷新。
恒拓信息科技 2010-08-02
  • 打赏
  • 举报
回复
datagridvile如果是绑定数据库的话,有两种刷新方式,
一是:重新绑定数据库,
二是:你可以修改完数据后,不重新绑定,直接也把你第一次绑定到你datagridvile上的dataTale里的对应项改了,页面上的数据也就跟着改了,这样也可以及时刷新,而且效率很高,
j1988815love 2010-08-02
  • 打赏
  • 举报
回复
都试下了在写上去好吧 错的还写
zj8092 2010-06-02
  • 打赏
  • 举报
回复
this.dataGridView1.DataSource= ”datatable“
-汪帆- 2010-06-02
  • 打赏
  • 举报
回复
winform里的datagridView没有绑定方法,7楼的方法可以试试
zhoubupt 2010-06-02
  • 打赏
  • 举报
回复
恩,必须重新绑定下数据源,才嫩update数据
灵雨飘零 2010-06-02
  • 打赏
  • 举报
回复
dataGridView1.DataBind();添加完毕之后重新绑定一下datagridview的数据源
醒子宇 2010-06-02
  • 打赏
  • 举报
回复
楼上有答案了``
冰凝瞬间1986 2010-06-02
  • 打赏
  • 举报
回复
添加完毕之后重新绑定一下datagridview的数据源
不懂装懂 2010-06-02
  • 打赏
  • 举报
回复
SqlDataReader sdr = cmd.ExecuteReader();
this.dataGridView1.DataSource = null;
this.dataGridView1.DataSource = sdr;
改为:
SqlDataAdapter da = new SqlDataAdapter(strSql, con);
da.Fill(ds);
this.dataGridView1.DataSource = null;
this.dataGridView1.DataSource = ds.Tables[0];
试试
fangzhang1981 2010-06-02
  • 打赏
  • 举报
回复
我用的是vs2005和sql2005
fangzhang1981 2010-06-02
  • 打赏
  • 举报
回复
改成this.dataGridView1.DataBind();之后出现错误提示
错误 1 “System.Windows.Forms.DataGridView”并不包含“DataBind”的定义
birdlonger 2010-06-02
  • 打赏
  • 举报
回复
图片不可见.
shighui 2010-06-02
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 louti 的回复:]
SqlDataReader sdr = cmd.ExecuteReader();
this.dataGridView1.DataSource = null;
this.dataGridView1.DataSource = sdr;

this.dataGridView1.DataBind();
con.Close();
[/Quote]


正解!
加载更多回复(2)
DataGridView打印控件和.NET轻松打印控件5.0版(含报表模板设计组件)2012年5月12日修改完成,完全免费,在.NET2.0及以上环境下都可以使用(VB、C#等都可以用),有帮助文档与使用实例。 与4.95版相比,控件5.0版的主要更改如下: 1、解决了生成预览及打印过程中的状态窗口中显示的“第 页共 页”问题,现在可以正确显示总页数。 2、增加了打印DataGridView中选定内容(选定行、列或矩形区域)的功能。对DGVPrint组件,设置PrintRange属性为相应的值即可,而对于VB2008Print组件,请先用CopyDataGridViewSelectedRange函数将要打印的DGV复制到新的DGV,然后再用PrintDGV函数打印这个新DGV即可。 3、增加了大量的绘图函数(如路径、多边形、填充多边形、曲线等),基本上.NET的GDI+绘图函数都有了(注意,填充类绘图函数名称为DrawFill……,而不是GDI+的Fill…。另外,对于Brush参数,只支持SolidBrush、TextureBrush、LinearGradientBrush三种类型的画刷,而且对于后2个画刷,只支持其中的主要属性。 4、增加了直接打印Panel、GroupBox等容器控件中的内容的DrawPanel函数(对容器中的TextBox控件与Label控件以文本的形式打印,除此之外的其他除容器控件之外的控件如CheckBox、ComboBox、Button控件等则直接以图片的形式打印,函数还支持嵌套容器控件的打印,且如果一页打印不下具有自动换页续打功能)。借助该函数的功能,您可以在Panel等容器控件中设计好要打印的内容及打印相对位置,控件轻松帮助您解决打印问题。(参见演示实例) 5、增加了报表文件及模板文件的自动关联功能。在运行了“打印控件安装.msi”文件安装了打印控件的前提下,双击报表文件(扩展名为you的文件)即可打印预览该报表的内容;双击报表模板文件(扩展名为mb的文件)即可进入报表模板修改界面(此时如果打印预览报表模板不会有数据,因为这样修改报表模板时是没有设置数据源的)。 6、解决了原EasyReport报表组件由于资源释放不及时,在多次重复使用时占用大量句柄而可能产生的不能打印或预览问题。 7、解决了DataGridView在有固定列(冻结列)的时候,有些情况下(DGV固定列的index与DisplayIndex不一致时)打印可能出错的问题。 8、DGVPrint组件的自定义纸张使用更方便,设计时在可以通过设置PaperHeight与PaperWidth属性设置,运行时在“打印参数”设置窗口中也可设置自定义纸张大小。 9、解决了EasyReport组件“页表头”区域设置的背景图片覆盖该区域打印内容的问题。 10、增加了打印XML格式的HTML文档的功能(目前只支持部分HTML标记,不支持表格及图片等标记,请参见DrawXML函数) 11、对帮助文件做了进一步的修订 12、增加了很多新的演示实例。 13、其他一些完善和修改。 本控件特色: 1、强大的DataGridView打印功能,不仅可以以多种形式(普通打印、分栏打印、跨页打印、工资条打印)打印DataGridView表格,基本上能完全按DataGridView控件本身设置的格式如字体、字号、背景颜色、前景颜色、单元格对齐方式等打印出来,文字图像都可以打印,而且是完全根据表格当前的显示顺序进行打印的,如果您在使用时调整了列的顺序,刷新打印后就会按调整后的列显示顺序进行打印,基本上做到了所见即所得的打印。 2、报表设计功能,这是4.7版控件的新增功能。报表模板设计组件EasyReport与WebEasyReport组件可以设计普通报表、分组报表、套打模板等,分别以DataGridView和GridView为数据源。控件的位置以毫米为计量单位,定位准确,很适合套打单据设计。 3、分组汇总打印DataGridVeiw功能,每组还可以自动换新页打印,还可以自动增加行号。 4、强大的文本打印输出功能,有多个文本打印重载函数,打印文本时,如果需要,控件会自动换行或换页打印输出。 5、支持同一文档多种版面格式打印(类似于Word中的节的功能):对同一份文档,不同的页面可以设置不同的格式(纸张大小、纸张方向、页边距),只需要在新增一页时在NewPage方法中指定要使用的页面格式即可,使用非常简单。 6、报表文件保存功能。本控件允许将当前打印预览的内容保存为报表文件,以后使用本控件重新打开该报表文件即可重现原来保存报表时的打印内容。 7、打印方案保存与读取功能。可以将当前打印参数保存为打印方案文件,或都从保存的打印方案文件中读取打印参数。 8、水印

110,500

社区成员

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

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

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