| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1492 人关注过本帖
标题:帮我解释一下这段代码
只看楼主 加入收藏
liangshanyua
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2017-2-3
结帖率:0
收藏
已结贴  问题点数:20 回复次数:4 
帮我解释一下这段代码
Private Sub ListKm()
        Set Rst1 = New Recordset
        sql = "select * from 学科表 order by 序号"
        Rst1.Open sql, db, 1, 3
        
        If Rst1.EOF Then
            GridDW.Clear
            GridDW.Rows = 1
            GridDW.FormatString = "^ 序号|^  学科 |^  总分 |^  差生分 |^  及格分 |^  优秀分|^  尖子分 "
            Exit Sub
        Else
            Rst1.MoveLast
            Rst1.MoveFirst
        End If
        
        GridDW.Clear
        GridDW.Rows = 1
        GridDW.FormatString = "^ 序号|^  学科 |^  总分 |^  差生分 |^  及格分 |^  优秀分|^  尖子分 "
        Do While Not Rst1.EOF
            GridDW.Rows = GridDW.Rows + 1
            GridDW.TextMatrix(GridDW.Rows - 1, 0) = Rst1.Fields(0)
            GridDW.TextMatrix(GridDW.Rows - 1, 1) = Rst1.Fields(1)
            GridDW.TextMatrix(GridDW.Rows - 1, 2) = Rst1.Fields(2)
            GridDW.TextMatrix(GridDW.Rows - 1, 3) = Rst1.Fields(3)
            GridDW.TextMatrix(GridDW.Rows - 1, 4) = Rst1.Fields(4)
            GridDW.TextMatrix(GridDW.Rows - 1, 5) = Rst1.Fields(5)
            GridDW.TextMatrix(GridDW.Rows - 1, 6) = Rst1.Fields(6)
            Rst1.MoveNext
        Loop

End Sub
2017-02-03 13:11
风吹过b
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:贵宾
威 望:364
帖 子:4937
专家分:30047
注 册:2008-10-15
收藏
得分:7 
Private Sub ListKm()
        Set Rst1 = New Recordset               '使用的表对象
        sql = "select * from 学科表 order by 序号"       '定义SQL命令
        Rst1.Open sql, db, 1, 3                '打开表,db 是数据连接
        
        If Rst1.EOF Then                       '如果没有记录
            GridDW.Clear                       '清除表格
            GridDW.Rows = 1                    '表格设置为一行
            GridDW.FormatString = "^ 序号|^  学科 |^  总分 |^  差生分 |^  及格分 |^  优秀分|^  尖子分 "   '表格头
            Exit Sub
        Else
            Rst1.MoveLast                  '数据指针最后一行
            Rst1.MoveFirst                 '数据指针第一行,这样的做的结果是让数据全部缓冲,可以读取正确的数据行数.
        End If
        
        GridDW.Clear
        GridDW.Rows = 1
        GridDW.FormatString = "^ 序号|^  学科 |^  总分 |^  差生分 |^  及格分 |^  优秀分|^  尖子分 "
        Do While Not Rst1.EOF            '循环开始,直到表结尾
            GridDW.Rows = GridDW.Rows + 1          '加地行
            GridDW.TextMatrix(GridDW.Rows - 1, 0) = Rst1.Fields(0)            '用每一个字段进行填充.这种写法,严格依赖数据库结构,
            GridDW.TextMatrix(GridDW.Rows - 1, 1) = Rst1.Fields(1)            '修改建议:在SQL命令中按照使用顺序写出字段列表来.不要使用默认顺序
            GridDW.TextMatrix(GridDW.Rows - 1, 2) = Rst1.Fields(2)
            GridDW.TextMatrix(GridDW.Rows - 1, 3) = Rst1.Fields(3)
            GridDW.TextMatrix(GridDW.Rows - 1, 4) = Rst1.Fields(4)
            GridDW.TextMatrix(GridDW.Rows - 1, 5) = Rst1.Fields(5)
            GridDW.TextMatrix(GridDW.Rows - 1, 6) = Rst1.Fields(6)
            Rst1.MoveNext          '下一条记录
        Loop

End Sub

授人于鱼,不如授人于渔
早已停用QQ了
2017-02-03 15:40
ZHRXJR
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:125
帖 子:1034
专家分:5519
注 册:2016-5-10
收藏
得分:7 
回复 楼主 liangshanyua
感到你的这个程序好像有点不太合理,不知道你的 GridDW 控件是什么控件,我使用的是 MSHFlexGrid控件 ,控件名称也是GridDW,供你参考:
程序代码:
Dim db As New ADODB.Connection, Rs As New ADODB.Recordset      '引用了ADO对象后在通用部分定义db 数据库连接对象、Rs 记录集对象

Private Sub Form_Load()
Dim XX As Integer, sql As String     '在过程中养成定义变量的习惯,防止不定义就使用变量
db.Open "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" & App.Path & "\aaa.mdb;Persist Security Info=False"   '连接到数据库(数据库是随便找的一个,与你的数据库可能不同)
    sql = "select * from 会员登录表 order by ID"   '给SQL连接数据表的字符串赋值
    Rs.Open sql, db, 3, 2   '打开数据表,db 是连接数据库的对象
    XX = Rs.RecordCount    '得到数据表的总记录数
    GridDW.Clear     '初始化GridDW控件,我使用的是 MSHFlexGrid控件 ,控件名称是GridDW
    With GridDW    '设置GridDW块
        .Rows = XX + 1    '得到GridDW控件的总行数
        .FormatString = "^ 序号|^  会员名 |^  密码 |^  姓名 |^  性别 |^  年龄|^         地址 "    '设置GridDW控件的表头字符串
        For I = 1 To XX      '循环,循环次数是记录集的总行数
            .TextMatrix(I, 0) = Rs.Fields(0)
            .TextMatrix(I, 1) = Rs.Fields(1)      'I 是GridDW控件 Row 的值
            .TextMatrix(I, 2) = Rs.Fields(2)      '显示记录,建议使用 “Rs!字段名称”或“Rs("字段名称")” 比较灵活
            .TextMatrix(I, 3) = Rs.Fields(3)
            .TextMatrix(I, 4) = Rs.Fields(4)
            .TextMatrix(I, 5) = Rs.Fields(5)
            .TextMatrix(I, 6) = Rs.Fields(8)
            Rs.MoveNext   '移到记录集指针到下一条记录
        Next I    '循环变量 I 加1,如果 I>=XX,将退出循环
    End With   '退出GridDW块
    Rs.Close    '关闭记录集对象
    Set Rs = Nothing   '记录集对象从内存清除
db.Close   '关闭数据库连接对象
Set db = Nothing   '数据库连接对象从内存清除
End Sub

数据库是我随便找的一个数据库,当然数据表也不一样的,仅供参考。
图片附件: 游客没有浏览图片的权限,请 登录注册

请不要选我!!!
2017-02-04 12:39
初始元灵
Rank: 2
等 级:论坛游民
帖 子:72
专家分:46
注 册:2016-10-10
收藏
得分:7 
回复 2楼 风吹过b
风版,意思是用SQL的Insert语句吗?

三清之始
2017-02-06 10:40
风吹过b
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:贵宾
威 望:364
帖 子:4937
专家分:30047
注 册:2008-10-15
收藏
得分:0 
'修改建议:在SQL命令中按照使用顺序写出字段列表来.不要使用默认顺序

 sql = "select * from 学科表 order by 序号"       '定义SQL命令
这个 * 号按所要求的字段顺序 显式写出来,而不是按默认顺序。


 sql = "select [序号],[会员名],[密码],[姓名],[性别],[年龄],[地址] from 学科表 order by 序号"       '定义SQL命令

授人于鱼,不如授人于渔
早已停用QQ了
2017-02-08 08:36
快速回复:帮我解释一下这段代码
数据加载中...
 
   



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

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