ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

【求助】用excel 调用sql server中的数据 查询语句如何写

[复制链接]

TA的精华主题

TA的得分主题

发表于 2015-7-3 09:31 | 显示全部楼层 |阅读模式
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列。
1、这是我写的查询语句:
    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)"    '定义SQL查询命令字符串rs.MOVENEXT

    求高手指点,这个查询语句应该怎么改?

2、sht.Cells(i,2) 如果 i 取值是 1 到 10 ,那么得用循环吧 ,怎么样表示这个循环?




TA的精华主题

TA的得分主题

 楼主| 发表于 2015-7-14 10:00 | 显示全部楼层
已经解决了,非常感谢@roych
代码

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

您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-12-25 23:57 , Processed in 0.032810 second(s), 9 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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