如何配置一个sql server使得其它用户可以通过excel odbc获取数据

要让其他用户通过 Excel 使用 ODBC 连接到 SQL Server 获取数据,你需要完成以下配置步骤:


✅ 一、在 SQL Server 端配置(服务器设置)

1. 启用 TCP/IP 协议

  • 打开 "SQL Server 配置管理器"。
  • 导航到:SQL Server 网络配置Protocols for MSSQLSERVER(或你的实例名)。
  • 确保 TCP/IP已启用

2. 配置 SQL Server 身份验证方式为"混合模式"

  • 打开 SSMS,连接服务器。
  • 右键点击服务器 → 属性 → 安全性
  • 选择:SQL Server 和 Windows 身份验证模式(混合模式)
  • 重启 SQL Server 服务。

3. 添加 SQL Server 登录账户

sql 复制代码
-- 创建一个登录用户
CREATE LOGIN testuser WITH PASSWORD = 'StrongPassword123!';

-- 在具体数据库中创建用户并授权
USE YourDatabaseName;
CREATE USER testuser FOR LOGIN testuser;
ALTER ROLE db_datareader ADD MEMBER testuser;  -- 只读权限

✅ 二、防火墙设置

确保 SQL Server 所在服务器允许外部访问其端口(默认端口是 1433):

  • 开放防火墙端口 1433(TCP)
  • 可通过命令添加(Windows):
powershell 复制代码
netsh advfirewall firewall add rule name="SQL Server" dir=in action=allow protocol=TCP localport=1433

✅ 三、客户端配置(在用户的电脑上设置 ODBC)

1. 打开 ODBC 管理器:

  • Windows 搜索 ODBC,打开 ODBC 数据源(32位或64位)

2. 添加新数据源(DSN):

  • 选择 SQL ServerODBC Driver for SQL Server

  • 配置连接信息:

    • 服务器名称 :输入 IP 地址或主机名(如:192.168.1.10sql.myserver.com)。
    • 登录方式 :选择 SQL Server 身份验证,输入 testuser 和密码。
    • 数据库:选择或输入你想访问的数据库名称。

3. 测试连接 → 成功 → 保存 DSN 名。


✅ 四、在 Excel 中使用 ODBC 获取数据

  1. 打开 Excel。
  2. 点击:数据获取数据自其他源来自 ODBC
  3. 选择刚刚配置的 DSN。
  4. 登录后,选择数据库中的表或视图 → 导入。

✅ 可选:为多个用户部署统一配置

  • 将 DSN 信息打包为 .dsn 文件,复制到用户电脑。
  • 用 VBA 或脚本实现 Excel 自动刷新。

🛡️ 安全建议

  • 使用强密码。
  • 只给用户授予 db_datareader 权限,避免写操作。
  • 可通过视图限制他们访问的数据范围。

相关推荐
KeThink7 小时前
国民经济行业分类 GB/T 4754—2017 (PDF和exce版本)
pdf·excel
_oP_i7 小时前
Excel 的多线程特性
excel
V1ncent Chen10 小时前
Excel基础:数据查看
excel
谁他个天昏地暗20 小时前
Java 实现 Excel 文件对比与数据填充
java·开发语言·excel
梦想blog20 小时前
Spring Boot + Easy Excel 自定义复杂样式导入导出
excel
UrbanJazzerati1 天前
使用Excel制作多类别占比分析字母饼图
excel
The Future is mine2 天前
Python实现文件夹中文件名与Excel中存在的文件名进行对比,并进行删除操作
excel
Tomorrow'sThinker2 天前
[特殊字符] Excel 读取收件人 + Outlook 批量发送带附件邮件 —— Python 自动化实战
python·excel·outlook
盛夏绽放2 天前
ExcelJS 完全指南:专业级Excel导出解决方案
excel·有问必答
bing_1582 天前
Excel 如何进行多条件查找或求和?
excel