| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2466 人关注过本帖
标题:datagridview 重设数据源问题
只看楼主 加入收藏
shenhaoli
Rank: 1
等 级:新手上路
帖 子:24
专家分:2
注 册:2010-4-15
结帖率:75%
收藏
已结贴  问题点数:20 回复次数:13 
datagridview 重设数据源问题
datagridview 重设数据源后,原来数据源中有的列无法移除!!
试了一下
 DataGridView1.DataSource = Nothing
        Dim k As Integer = DataGridView1.ColumnCount - 1
        For j As Integer = 0 To k
            DataGridView1.Columns.Clear()
            DataGridView1.Columns.Remove(j)
        Next
        DataGridView1.Refresh()
仍不行,不要和我说重载表单
搜索更多相关主题的帖子: 数据源 datagridview 重设 
2010-04-18 13:45
不说也罢
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:贵宾
威 望:39
帖 子:1481
专家分:4989
注 册:2007-10-7
收藏
得分:0 
楼主是在设计是为DataGridView1绑定了数据源?
建议使用代码动态绑定

===================================================
讨厌C#的行尾的小尾巴;和一对大括号{ }
===================================================
2010-04-18 16:02
shenhaoli
Rank: 1
等 级:新手上路
帖 子:24
专家分:2
注 册:2010-4-15
收藏
得分:0 
图片附件: 游客没有浏览图片的权限,请 登录注册

是动态绑定的,我刚从VB6.0转过来,为了熟悉数据库,做了这样一个小程序,界面如上
单击“连接数据库”则显示数据所含表
单击“打开并绑定表”则显示包含字段名称并绑定到datagridview1
可以通过包含字段查看,该字段的类型!
现在其它功能都成了,只是更改表后,datagridview1数据不同步
Public ds As New Data.DataSet()
Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdopen.Click
        Dim dbaname As String = txtdba.Text '指定数据库文件路径及名称
        Dim connStr As String = "provider=Microsoft.Jet.OLEDB.4.0; Data Source=" & CurDir() & dbaname
        Dim tabname As String = cmbtable.Text
        Dim conn As OleDb.OleDbConnection = New OleDb.OleDbConnection(connStr)
        Dim cmd As OleDb.OleDbCommand = New OleDb.OleDbCommand
        Dim sql As String = "select * from " & tabname
        conn.Open()
        cmd.Connection = conn
        Dim da As OleDb.OleDbDataAdapter = New OleDb.OleDbDataAdapter(sql, conn)

        ds.Clear()
        da.Fill(ds, "pylj")
        DataGridView1.DataSource = Nothing
        Dim k As Integer = DataGridView1.ColumnCount - 1
        For j As Integer = 0 To k
            DataGridView1.Columns.Clear()
            DataGridView1.Columns.Remove(DataGridView1.SelectedColumns(j))
        Next
        DataGridView1.Refresh()
        MsgBox("d")
        DataGridView1.DataSource = ds.Tables(0)

        Dim n As Integer = ds.Tables(0).Columns.Count - 1
        Dim y As Integer = cmbfiled.Items.Count - 1
        For x As Integer = 0 To y

            cmbfiled.Items.Clear()
        Next
        cmbfiled.Refresh()

        For i As Integer = 0 To n
            cmbfiled.Items.Add(ds.Tables(0).Columns(i).ColumnName)

        Next

        cmbfiled.SelectedIndex = 0
    End Sub
这是打开表并绑定的代码,为了方便,把ds数据集设成全局变量
请高手指点

[ 本帖最后由 shenhaoli 于 2010-4-18 18:19 编辑 ]
2010-04-18 18:17
不说也罢
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:贵宾
威 望:39
帖 子:1481
专家分:4989
注 册:2007-10-7
收藏
得分:0 
你既在学习,传项目上来,我给你看看,将你觉得有问题的地方做个注释标记

===================================================
讨厌C#的行尾的小尾巴;和一对大括号{ }
===================================================
2010-04-18 18:20
不说也罢
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:贵宾
威 望:39
帖 子:1481
专家分:4989
注 册:2007-10-7
收藏
得分:0 
在设计状态下,不要给DataGridView1绑定数据源

For j As Integer = 0 To k
            DataGridView1.Columns.Clear()
            DataGridView1.Columns.Remove(DataGridView1.SelectedColumns(j))
Next
你先把这几行代码注释掉,然后试试

===================================================
讨厌C#的行尾的小尾巴;和一对大括号{ }
===================================================
2010-04-18 18:23
shenhaoli
Rank: 1
等 级:新手上路
帖 子:24
专家分:2
注 册:2010-4-15
收藏
得分:0 
回复 楼主 shenhaoli
我把我的项目传上来,frm_data
运行时:数据库操作——》access
练习.rar (430.28 KB)
2010-04-18 18:33
不说也罢
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:贵宾
威 望:39
帖 子:1481
专家分:4989
注 册:2007-10-7
收藏
得分:0 
楼主的工程我看了,运行时没什么问题啊
楼主要问的是不是单击“包含表”的右边下拉框时,DataGridView1数据不同步呢?

===================================================
讨厌C#的行尾的小尾巴;和一对大括号{ }
===================================================
2010-04-18 18:43
shenhaoli
Rank: 1
等 级:新手上路
帖 子:24
专家分:2
注 册:2010-4-15
收藏
得分:0 
是的,然后单击“打开表并绑定”datagridview1 同步有问题

[ 本帖最后由 shenhaoli 于 2010-4-18 18:53 编辑 ]
2010-04-18 18:52
不说也罢
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:贵宾
威 望:39
帖 子:1481
专家分:4989
注 册:2007-10-7
收藏
得分:0 
回复 8楼 shenhaoli
我这里运行没问题,请将你说的问题详细描述一下
这里的数据与表都相符的

===================================================
讨厌C#的行尾的小尾巴;和一对大括号{ }
===================================================
2010-04-18 18:57
shenhaoli
Rank: 1
等 级:新手上路
帖 子:24
专家分:2
注 册:2010-4-15
收藏
得分:0 
图1先打开cyc表,图2是打开pylj表,datagridview1里仍有cyc表里的列
图片附件: 游客没有浏览图片的权限,请 登录注册
图片附件: 游客没有浏览图片的权限,请 登录注册
2010-04-18 19:07
快速回复:datagridview 重设数据源问题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.036015 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved