设为首页收藏本站Access中国

Office中国论坛/Access中国论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

返回列表 发新帖
查看: 2652|回复: 5
打印 上一主题 下一主题

[查询] 如何把一个一对多的记录变为多个一对一的记录?

[复制链接]
跳转到指定楼层
1#
发表于 2010-2-5 14:59:46 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
本帖最后由 执成 于 2010-2-5 15:53 编辑

如何把这样一组数据:
甲班:小王,小李,小赵,小钱,小黄
乙班:小刘,小王,小沈,小钱




转化为:

甲班:小王
甲班:小李
甲班:小赵
甲班:小钱
甲班:小黄
乙班:小刘
乙班:小王
乙班:小沈
乙班:小钱


本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 分享淘帖 订阅订阅
2#
发表于 2010-2-5 16:08:01 | 只看该作者
本帖最后由 红尘如烟 于 2010-2-5 16:12 编辑

  1.     Dim strName() As String
  2.     Dim intCount As Integer
  3.     Dim intI As Integer   
  4.     Dim rst As New ADODB.Recordset

  5.     rst.Open "表1", CurrentProject.Connection, adOpenKeyset, adLockOptimistic
  6.     Do Until rst.EOF
  7.         strName() = Split(rst!姓名, ",")
  8.         intCount = UBound(strName)
  9.         If intCount > 0 Then
  10.             For intI = 0 To intCount
  11.                 CurrentDb.Execute "INSERT INTO 表2(班级,姓名) SELECT '" & rst!班级 & "','" & strName(intI) & "' FROM 表1"
  12.             Next
  13.         End If
  14.         rst.MoveNext
  15.     Loop
  16.     rst.Close
  17.     Set rst = Nothing
复制代码
3#
发表于 2010-2-5 22:35:57 | 只看该作者
又受教了一回,谢谢红尘...
4#
发表于 2010-2-6 09:53:29 | 只看该作者
学习学习
5#
发表于 2010-2-20 23:05:18 | 只看该作者
学习
6#
发表于 2010-2-22 14:33:41 | 只看该作者
学习了
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|站长邮箱|小黑屋|手机版|Office中国/Access中国 ( 粤ICP备10043721号-1 )  

GMT+8, 2024-11-18 10:55 , Processed in 0.085133 second(s), 30 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表