如何配置一个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 权限,避免写操作。
  • 可通过视图限制他们访问的数据范围。

相关推荐
城数派3 小时前
1958-2024年乡镇的逐月土壤湿度数据
数据库·arcgis·数据分析·excel
派大星的日常3 小时前
64位windo系统安装ODBC链接工具并进行EXCEL数据连接
数据库·excel
Codiggerworld4 小时前
Vim高级招式:宏、寄存器、标记
excel
蜘蛛小助理7 小时前
从 Excel 到多维表:蜘蛛表格如何解决传统数据库开发与维护痛点
数据库·人工智能·excel·数据库开发·多维表·多维表格·蜘蛛表格
123的故事7 小时前
微软365Excel配合本地艺术二维码API在指定单元格动态生成二维码
excel·二维码·艺术二维码·自制二维码生成工具
asdzx678 小时前
使用 C# 添加或读取 Excel 公式:完整指南
开发语言·c#·excel
开开心心就好8 小时前
免费开源的网课教学屏幕画板工具
windows·eureka·计算机外设·word·excel·etcd·csdn开发云
fengyehongWorld8 小时前
EXCEL XLOOKUP函数
excel
城数派8 小时前
2000-2024年省市县三级的逐月归一化植被指数(NDVI)数据
数据库·arcgis·信息可视化·数据分析·excel
HealthScience1 天前
vscode使用Excel插件导致codex插件无法粘贴图片
服务器·vscode·excel