ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

向sql数据库表写入数据求助!!

[复制链接]

TA的精华主题

TA的得分主题

发表于 2020-8-31 09:30 | 显示全部楼层 |阅读模式
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
录入代码有问题,不知道怎么修改了。结果如下图,请大神指教该如何修改(如果按列名列分别指定,代码行数较多,所以想用循环)。
Sub 录入记录()
Dim conn As New ADODB.Connection
Dim rs As ADODB.Recordset
Dim i As Integer
Dim SQL As String
Dim val As String
    Set ws = Sheet2 '确定录入数据所在表
        '建立与SQL Server数据库的连接
    conn.ConnectionString = "Provider=SQLOLEDB;" _
    & "Server=192.168.1.162;" _
    & "uid=abc;" _
    & "pwd=sa;" _
    & "Database=cwb"
    conn.Open
    '向数据表中添加新记录
    SQL = "select * from " & Range("a1").Text & ""
    Set rs = New ADODB.Recordset
    rs.Open SQL, conn, adOpenKeyset, adLockOptimistic
     For i = 3 To ws.Range("a50000").End(xlUp).Row
     For j = 1 To 10
        rs.AddNew
        rs.Fields(j - 1) = ws.Cells(i, j)
        Next j
        Next i
          rs.Update
    rs.Close
    conn.Close
    Set rs = Nothing
    Set conn = Nothing
    MsgBox "成功保存数据!", vbInformation, "scdy 记录": Exit Sub
End Sub
image.png

TA的精华主题

TA的得分主题

发表于 2020-9-1 16:15 | 显示全部楼层
指定列名,可以通过:
for i = 0 to rst.fileds.count-1
rst.fields(i).name处理。
不过,个人更倾向于在SQL server里写存储过程导入;如果没法使用SQL server的话,则考虑链接表(SQL server以及Excel),再创建追加查询(把Excel的数据追加到SQL server里)。——当然,前提是Excel没啥表头,合并单元格之类乱七八糟的东西。

TA的精华主题

TA的得分主题

 楼主| 发表于 2020-9-2 08:39 | 显示全部楼层
roych 发表于 2020-9-1 16:15
指定列名,可以通过:
for i = 0 to rst.fileds.count-1
rst.fields(i).name处理。

衷心感谢指导!查了一堆资料,已解决了。     For j = 1 To 10        rs.AddNew原来此两句顺序不对,调换下前后位置就OK了。
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

关闭

最新热点上一条 /1 下一条

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

GMT+8, 2024-4-25 13:23 , Processed in 0.037611 second(s), 10 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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