百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

VBA连接SQL SEVER通用壳子(vba中sql查找的数据不显示单元格颜色)

liuian 2025-03-24 17:59 10 浏览

Sub ConnectToSQLServer()

' 定义变量

Dim conn As Object ' ADODB 连接对象

Dim rs As Object ' ADODB 记录集对象

Dim serverName As String ' SQL Server 实例名称

Dim dbName As String ' 数据库名称

Dim sqlQuery As String ' SQL 查询语句

Dim outputSheet As Worksheet ' 目标工作表

Dim rowCounter As Long ' 字段计数器


' 设置连接参数

serverName = "localhost" ' SQL Server 实例名(本地默认)

dbName = "AdventureWorks" ' 数据库名称

sqlQuery = "SELECT TOP 100 * FROM Sales.SalesOrderHeader" ' 查询前100行数据


' 创建对象实例

Set conn = CreateObject("ADODB.Connection") ' 创建数据库连接

Set rs = CreateObject("ADODB.Recordset") ' 创建记录集(用于存储查询结果)

Set outputSheet = ThisWorkbook.Sheets("Sheet1") ' 指定数据输出的工作表


' 构建连接字符串(使用 Windows 集成身份验证)

conn.ConnectionString = _

"Provider=SQLOLEDB;" & _ ' 指定 OLEDB 驱动

"Data Source=" & serverName & ";" & _ ' 服务器地址

"Initial Catalog=" & dbName & ";" & _ ' 数据库名称

"Integrated Security=SSPI;" ' 使用 Windows 账户验证


' 打开数据库连接

conn.Open


' 执行 SQL 查询

rs.Open sqlQuery, conn ' 将查询结果存入记录集


' 清空目标工作表

outputSheet.Cells.Clear


' 写入字段名称(表头)

For rowCounter = 0 To rs.Fields.Count - 1

outputSheet.Cells(1, rowCounter + 1).Value = rs.Fields(rowCounter).Name

Next rowCounter


' 将记录集数据写入工作表(从 A2 开始)

outputSheet.Range("A2").CopyFromRecordset rs


' 关闭连接与释放资源

rs.Close

conn.Close

Set rs = Nothing ' 释放记录集对象

Set conn = Nothing ' 释放连接对象


MsgBox "数据导入完成!"

End Sub


说明. 关于连接字符串(Connection String)


conn.ConnectionString = "Provider=SQLOLEDB;Data Source=localhost;Initial Catalog=AdventureWorks;Integrated Security=SSPI;"

```

- **`Provider=SQLOLEDB`**:

指定使用 SQL Server 的 OLEDB 驱动程序(需确保系统已安装)。

- **`Data Source`**:

SQL Server 实例名,格式为 `服务器名\实例名`(默认实例可简写为服务器名)。

- **`Initial Catalog`**:

目标数据库名称。

- **`Integrated Security=SSPI`**:

使用 Windows 账户身份验证(无需输入用户名密码)。

- 若用 SQL 账号验证,替换为:

`User ID=用户名;Password=密码;`

相关推荐

那些Java架构师必知必会的技术

Java基础#Java对象的内存布局MapStruct解了对象映射的毒周末我把HashMap源码又过了一遍Java7和Java8中的ConcurrentHashMap原理解析Java中自定...

Java内存泄漏最全详解(6大原因及解决方案)

大家好,我是mikechen。内存泄漏是经常出现的线上故障,也是大厂面试经常考察的,下面我就全面来详解内存泄漏以及解决方案@mikechen本篇已收于mikechen原创超30万字《阿里架构师进阶专题...

都说Feign是RPC,没有侵入性,为什么我的代码越来越像 C++

1.概览随着SpringCloud的流行性,Feign已经成为RPC的事实标准,由于其构建与Http协议之上,对请求和返回值缺少规范约束,在日常开发过程中经常由于设计不当对系统造成一...

面试题系列-java后端面试题List 和 Set 的区别

List和Set的区别List,Set都是继承自Collection接口List特点:元素有放入顺序,元素可重复,Set特点:元素无放入顺序,元素不可重复,重复元素会覆盖掉,(...

一直不理解为什么在重写equals方法时都要重写hashCode方法

为什么在重写equals方法时都要重写hashCode方法呢?首先jdk的要求是这样的,equals与hashcode间的关系:1、如果两个对象相同(即用equals比较返回true),那么它们的ha...

翻了ConcurrentHashMap1.7 和1.8的源码,我总结了它们的主要区别

ConcurrentHashMap思考:HashTable是线程安全的,为什么不推荐使用?HashTable是一个线程安全的类,它使用synchronized来锁住整张Hash表来实现线程安全,即每次...

10 个经典的 Java 集合面试题,看你能否答得上来?

来自:evget.com/article/2014/11/27/21869.html这里有10个经典的Java面试题,也为大家列出了答案。这是Java开发人员面试经常容易遇到的问题,相信你了解和掌握之...

MyBatis3.5.11-从入门到高阶

一.课程介绍MyBatis概述MyBatis基础应用MyBatis高级MyBatis进阶二.MyBatis概述1、为什么需要MyBatis在我们程序中,运行时期产生的数据都是存放在内存中的,那么在内存...

灵魂拷问:如何检查 Java 数组中是否包含某个值?

作者|沉默王二责编|Elle在逛programcreek的时候,我发现了一些专注细节但价值连城的主题。比如说:如何检查Java数组中是否包含某个值?像这类灵魂拷问的主题,非常值得深入地研...

Java后端学习路线是什么?

关于Java后端(SpringBoot为主)学习路线:一、Java基础阶段编程语言基础掌握基本数据类型(如int、double、char等)、变量、常量的定义和使用。理解运算符(算术、关...

Mybatis配置文件XML全貌详解,再不懂我也没招了

一、为什么要使用配置文件试想,如果没有配置文件,我们的应用程序将只能沿着固定的姿态运行,几乎不能做任何动态的调整,那么这不是一套完美的设计,因为我们希望拥有更宽更灵活的操作空间和更多的兼容度,同时也能...

软件性能调优全攻略:从瓶颈定位到工具应用

性能调优是软件测试中的重要环节,旨在提高系统的响应时间、吞吐量、并发能力、资源利用率,并降低系统崩溃或卡顿的风险。通常,性能调优涉及发现性能瓶颈、分析问题根因、优化代码和系统配置等步骤,调优之前需要先...

你还在使用Guava的Lists.newArrayList()吗

Guava说起Guava,做Java开发的应该没人不知道吧,毕竟“google出品,必属精品”。虽然应该没有Spring那样让Javaer无法避开,但是其中很多工具类的封装还是让人欲罢不能。而我们今天...

JDK成长记7:3张图搞懂HashMap底层原理

HashMap基本原理和优缺点HashMap基本原理和优缺点一句话讲,HashMap底层数据结构,JDK1.7数组+单向链表、JDK1.8数组+单向链表+红黑树。HashMap的3个底层原理Hash...

如何深度理解mybatis?

深度自定义mybatis回顾mybatis的操作的核心步骤编写核心类SqlSessionFacotryBuild进行解析配置文件深度分析解析SqlSessionFacotryBuild干的核心工作编写...