ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

求助,连接SQL数据库的问题

[复制链接]

TA的精华主题

TA的得分主题

发表于 2017-7-14 11:25 | 显示全部楼层 |阅读模式
抄了网上不少代码,都不能正常用
SQL服务器IP 10.32.8.2
账号和密码都是wxf

想要一个连接服务器的代码,求高手老师帮帮忙

QQ截图20170714112635.jpg

TA的精华主题

TA的得分主题

 楼主| 发表于 2017-7-14 11:28 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
不确定是不是还需要其他什么信息,反正就是搞不定,求指导

TA的精华主题

TA的得分主题

发表于 2017-7-15 07:07 来自手机 | 显示全部楼层
看这已经连上了,链接字符串,第一种:OLE DB或OleDbConnection (.NET)方式
(使用SQL Server的Microsoft OLE DB提供程序)
Provider=sqloledb; Data Source=服务器IP; Initial Catalog=数据库名; User Id=用户名; Password=密码;


第二种:ODBC方式(使用ODBC的Microsoft OLE DB提供程序)
Driver={SQL Server}; Server=服务器IP; Database=数据库名; Uid=用户名; Pwd=密码;

TA的精华主题

TA的得分主题

发表于 2017-7-15 07:13 来自手机 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
百度了一篇,供参考
Excel VBA 使用ADODB 连接SqlServer

Private Sub CommandButton1_Click()

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=43AFBDDA6DC04E1;Database=ERPFram;Uid=sa;Pwd=;"    '定义数据库链接字符串

'下面的语句将读取数据表数据,并将它保存到excel工作表中:画两张表想像一下,工作表为一张两维表,记录集也是一张两维表
strSQL = "select LoginName,Name from Users"    '定义SQL查询命令字符串
cn.Open strCn   '与数据库建立连接,如果成功,返回连接对象cn
rs.Open strSQL, cn '执行strSQL所含的SQL命令,结果保存在rs记录集对象中
i = 1
Set sht = ThisWorkbook.Worksheets("sheet1")   '把sht指向当前工作簿的sheet1工作表
Do While Not rs.EOF     '当数据指针未移到记录集末尾时,循环下列操作
    ComboBox1.AddItem (rs("LoginName"))
    ComboBox1.ListIndex = 0
    sht.Cells(i, 1) = rs("LoginName")    '把当前记录的字段1的值保存到sheet1工作表的第i行第1列
    sht.Cells(i, 2) = rs("Name")    '把当前字段2的值保存到sheet1工作表的第i行第2列
    rs.MoveNext                      '把指针移向下一条记录
    i = i + 1                        'i加1,准备把下一记录相关字段的值保存到工作表的下一行
Loop                                 '循环

rs.Close   '关闭记录集,至此,程序将把某数据表的字段1和字段2保存在excel工作表sheet1的第1、2列,行数等于数据表的记录数

End Sub

/*

'下面的语句将读取excel工作表数据,并将之简单计算后存入数据库,这里使用上面程序中的一些变量
'假设分别读取工作表sheet1第5行至第500行的第8列和第9列已存在的数据,然后将它们相乘,并将积存入数据库的某个表
strSQL=""    '清空上面定义的变量
for i=5 to 500 '循环开始,i从5到500s
    strSQL=strSQL & "insert into 表名(字段) values(" & sht.cells(i,8)*sht.cells(i,9) & ") ;"      '构造SQL命令串
next
'至此生成一串SQL命令串,保存的内容大概为:insert into 表名(字段) values(数值1);insert into 表名(字段) values(数值2);
cn.execute strSQL '执行该SQL命令串,如果SQL命令没有错误,将在数据库中添加501个记录;也可以用rs.open strSQL,cn 执行
cn.close '关闭数据库链接,释放资源



*/




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

本版积分规则

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

GMT+8, 2024-11-26 13:40 , Processed in 0.048818 second(s), 10 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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