当前位置: 首页 > news >正文

sql server如何创建表导入excel的数据

在 SQL Server 中,可以通过几种方式将 Excel 数据导入到数据库表中。下面是一个完整的流程,包括如何创建表,以及将 Excel 数据导入该表的方法:


✅ 方法一:使用 SQL Server Management Studio (SSMS) 的导入向导(推荐方式)

  1. 打开 SSMS 并连接到目标数据库。

  2. 右键点击数据库名 → Tasks(任务)Import Data(导入数据)

  3. 在导入向导中:

    • 数据源选择:Microsoft Excel
    • 文件名:选择你的 Excel 文件(后缀为 .xlsx.xls)。
    • Excel 版本:根据实际选择。
    • 是否首行为列名:勾选 “First row has column names”。
  4. 目标选择:SQL Server Native Client。

  5. 选择目标表(可以自动创建新表或映射已有表)。

  6. 点击 “Edit Mappings”(编辑映射),确认数据类型是否正确。

  7. 执行导入。

✳️ SSMS 会自动生成表结构,也可以在导入前手动建表再映射。


✅ 方法二:T-SQL + OPENROWSET(需配置)

步骤 1:开启 Ad Hoc Distributed Queries
EXEC sp_configure 'show advanced options', 1;
RECONFIGURE;
EXEC sp_configure 'Ad Hoc Distributed Queries', 1;
RECONFIGURE;
步骤 2:使用 OPENROWSET 导入(假设你的 Excel 在 C:\data.xlsx,Sheet 名为 Sheet1$):
SELECT * 
INTO NewTable
FROM OPENROWSET('Microsoft.ACE.OLEDB.12.0','Excel 12.0;Database=C:\data.xlsx;HDR=YES;IMEX=1','SELECT * FROM [Sheet1$]'
);

⚠️ 注意事项:

  • 要安装 Microsoft Access Database Engine 才能支持 ACE.OLEDB.12.0。
  • SQL Server 必须和 Excel 文件在同一台机器或共享路径可访问。

✅ 方法三:先创建表,再使用 SSIS 或 BULK INSERT

如果你已经知道表结构,可以手动创建表:

创建表:
CREATE TABLE ExcelData (ID INT,Name NVARCHAR(100),Age INT
);

然后使用导入工具(如导入向导、SSIS)或临时先导入到 staging 表再处理。


🔁 总结:

方法优点缺点
导入向导简单图形界面需手动操作
OPENROWSET可脚本化配置复杂,需驱动
SSIS / BULK INSERT自动化强设置成本高
http://www.lqws.cn/news/122419.html

相关文章:

  • 结节性甲状腺肿全流程大模型预测与决策系统总体架构设计方案大纲
  • 互联网大厂Java求职面试:云原生架构下的微服务网关与可观测性设计
  • MDP的recoders部分
  • Python基础:文件简单操作
  • .Net Framework 4/C# 属性和方法
  • 【手写系列】手写动态代理
  • C++——智能指针 weak_ptr
  • Java多线程:ThreadPoolTaskExecutor线程池 与CompletableFuture如何打出组合拳
  • Redisson - 实现延迟队列
  • [特殊字符] 深度剖析 n8n 与 Dify:使用场景、优劣势及技术选型建议
  • DA14531_beacon_大小信标设备开发
  • mysql 悲观锁和乐观锁(—悲观锁)
  • 电路设计基础-2
  • Redis-旁路缓存策略详解
  • JSON基础知识
  • Java 线程池原理详解
  • 分布式互斥算法
  • 使用ArcPy进行栅格数据分析
  • Axios 取消请求的演进:CancelToken vs. AbortController
  • rknn优化教程(一)
  • 海信IP810N-海思MV320芯片-安卓9-2+16G-免拆优盘卡刷固件包
  • 瀚文机械键盘固件开发详解:HWKeyboard.cpp文件解析与应用
  • Async-profiler 内存采样机制解析:从原理到实现
  • Docker慢慢学
  • Java 中 ArrayList、Vector、LinkedList 的核心区别与应用场景
  • 【Docker 从入门到实战全攻略(二):核心概念 + 命令详解 + 部署案例】
  • Spring Boot 从Socket 到Netty网络编程(下):Netty基本开发与改进【心跳、粘包与拆包、闲置连接】
  • java从azure中读取用户信息
  • Docker 常用命令详解
  • docker生命周期