ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 1267|回复: 7

[求助]用excel 调用sql server 2005中的数据

[复制链接]

TA的精华主题

TA的得分主题

发表于 2015-6-17 16:33 | 显示全部楼层 |阅读模式
本帖最后由 AntoniaQiao 于 2015-6-17 16:33 编辑

sql 中的表pricelist的结构为六列:pri_id(主键) ,pri_body, pri_gcyl , pri_fmkj, pri_price;
pri_body(对应excel的B列), pri_gcyl (对应excel的C列),  pri_fmkj(对应excel的D列)。
根据excel表格中 B ,C, D 中的内容查询pricelist表的pri_price,并将查询到的内容写入E列。


求高手指导。

Sub test()  '定义过程名称
Dim i As Integer, j As Integer, sht As Worksheet 'i,j为整数变量;sht 为excel工作表对象变量,指向某一工作表
Dim cn As New ADODB.Connection '定义数据链接对象 ,保存连接数据库信息;请先添加ADO引用
Dim rs As New ADODB.Recordset  '定义记录集对象,保存数据表
Dim strCn As String, strSQL As String '字符串变量
strCn = "Provider=sqloledb;Server=QIAOCY;Database=price;Uid=sa;Pwd=sa;"  '定义数据库连接字符串

'下面的语句将读取数据表数据,并将它保存到excel工作表中:画两张表想像一下,工作表为一张两维表,记录集也是一张两维表
cn.Open strCn   '与数据库建立连接,如果成功,返回连接对象cn
rs.Open strSQL, cn  '执行strSQL所含的SQL命令,结果保存在rs记录集对象中
Set sht = ThisWorkbook.Worksheets("sheet1")   '把sht指向当前工作簿的sheet1工作表
i = 1
Do While Not rs.EOF
strSQL = "select pri_price from  pricelist where pri_body==sht.Cells(i,2) pri_gcyl==sht.Cells(i,3) pri_fmkj==sht.Cells(i,4)"    '定义SQL查询命令字符串
rs.MOVENEXT
i = i + 1
Loop

i = 1
Do While Not rs.EOF     '当数据指针未移到记录集末尾时,循环下列操作
    sht.Cells(i, 5) = rs(pri_price)    '把当前记录的字段1的值保存到sheet1工作表的第i行第5列
    rs.MOVENEXT                      '把指针移向下一条记录
    i = i + 1                        'i加1,准备把下一记录相关字段的值保存到工作表的下一行
Loop                                 '循环
rs.Close   '关闭记录集,至此,程序将把某数据表的pri_price保存在excel工作表sheet1的第5列,行数等于数据表的记录数
cn.Close  '关闭数据库链接,释放资源
End Sub

新建文件夹 (3).rar

21.18 KB, 下载次数: 21

TA的精华主题

TA的得分主题

 楼主| 发表于 2015-6-17 16:43 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
数据库不知道怎么上传,这是图片
QQ图片20150617164037.png

TA的精华主题

TA的得分主题

 楼主| 发表于 2015-6-18 08:48 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
各位大神,帮我看看啊,我程序错在哪?

TA的精华主题

TA的得分主题

 楼主| 发表于 2015-6-23 08:58 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2015-6-24 09:54 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
没有附件怎么看

TA的精华主题

TA的得分主题

 楼主| 发表于 2015-6-29 09:12 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
rzz8118 发表于 2015-6-24 09:54
没有附件怎么看

要数据库的附件吗

TA的精华主题

TA的得分主题

 楼主| 发表于 2015-6-29 09:13 | 显示全部楼层
excel 附件

新建文件夹 (3).rar

21.18 KB, 下载次数: 7

TA的精华主题

TA的得分主题

 楼主| 发表于 2015-7-14 10:03 | 显示全部楼层
已经解决
代码
Sub test()  '定义过程名称
Dim i As Integer, j As Integer, sht As Worksheet 'i,j为整数变量;sht 为excel工作表对象变量,指向某一工作表
Dim cn As New ADODB.Connection '定义数据链接对象 ,保存连接数据库信息;请先添加ADO引用
Dim rst As New ADODB.Recordset  '定义记录集对象,保存数据表
Dim strCn As String, strSQL As String '字符串变量


strCn = "Provider=sqloledb;Server=QIAOCY;Database=price;Uid=sa;Pwd=sa;"  '定义数据库连接字符串


cn.Open strCn   '与数据库建立连接,如果成功,返回连接对象cn


'下面的语句将读取数据表数据,并将它保存到excel工作表中:画两张表想像一下,工作表为一张两维表,记录集也是一张两维表
Set sht = ThisWorkbook.Worksheets("sheet1")   '把sht指向当前工作簿的sheet1工作表
For i = 2 To Range("A1048576").End(xlUp).Row()

      strSQL = "select pri_price from  pricelist where pri_body ='" & sht.Cells(i, 2) & "'" & "and pri_gcyl =" & sht.Cells(i, 3) & " and pri_fmkj = " & sht.Cells(i, 4)
   
      rst.Open strSQL, cn
     '这里处理记录集语句
  
    sht.Cells(i, 5) = rst("pri_price")    '把当前记录的字段1的值保存到sheet1工作表的第i行第5列
    rst.Close
   
   
Next i

cn.Close  '关闭数据库链接,释放资源
End Sub
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-12-26 00:10 , Processed in 0.035007 second(s), 12 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

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