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

相关推荐
啊哈哈哈哈啊有18 小时前
导出树形结构,excel
java·windows·excel
Dxy12393102161 天前
Elasticsearch 聚合入门:像 Excel 透视表一样分析数据
elasticsearch·excel
一位代码1 天前
Excel | .xls 与 .xlsx 文件的区别及使用 Excel 打开 CSV 文件出现乱码的解决办法
excel
CodeCraft Studio1 天前
Excel处理控件Aspose.Cells教程:使用C#在Excel中创建树状图
前端·c#·excel·aspose·c# excel库·excel树状图·excel sdk
悟能不能悟1 天前
vue导出excel文件
前端·vue.js·excel
CodeCraft Studio1 天前
国产化Excel开发组件Spire.XLS教程:以Python编程方式在Excel中高亮重复值
开发语言·python·excel·spire.xls·excel自动化·excel高亮重复值·python处理excel
喝汽水的猫^2 天前
Java实现Excel 导出(多 Sheet、复杂格式)
java·excel
小费的部落2 天前
Excel 在Sheet3中 匹配Sheet1的A列和Sheet2的A列并处理空内容
java·前端·excel
缺点内向2 天前
如何在 C# 中重命名 Excel 工作表并设置标签颜色
开发语言·c#·excel
wtsolutions2 天前
Sheet-to-Doc: Automate Document Generation with Excel Data and Word Templates
word·excel·wtsolutions