Excel批量导入到数据库的方法

这两天在处理Excel批量导入到数据库,用了两种不同的方法:

1、把要导入的数据拼接成字符串,值用特殊字符分割

把上面的单元格复制到Vs ,用Alt键组合添加分割符,组成一行

光标移到尾,删除换行,删除空格和首字符,组成需要的字符串

DECLARE @StrWithPipe NVARCHAR(MAX) = N'C370225A0070|C370225A0070|C370225A0070|C370224A0036|C370224A0036|C370224A0036|C370224A0036|C370225A0035|C370225A0035|C370225A0035'

在网络上找了方法,改一下代码,直接使用

sql 复制代码
 -- 创建自定义函数:按|拆分字符串,返回包含每个值的表
CREATE FUNCTION dbo.fn_SplitByPipe (
    @InputStr NVARCHAR(MAX) -- 待拆分的字符串
)

RETURNS @SplitResult TABLE (SplitValue NVARCHAR(MAX)) -- 返回结果表(每行一个值)
AS
BEGIN
    -- 处理空字符串或NULL的情况
    IF @InputStr IS NULL OR LEN(@InputStr) = 0
        RETURN;

    -- 将字符串转换为XML格式(用|分隔符替换为XML节点)
    DECLARE @Xml XML = N'<root><item>' + 
                      REPLACE(@InputStr, N'|', N'</item><item>') + -- 用</item><item>替换|
                      N'</item></root>';

    -- 解析XML,提取所有<item>节点的值(即拆分后的每个元素)
    INSERT INTO @SplitResult (SplitValue)
    SELECT 
        T.c.value('.', 'NVARCHAR(MAX)') AS SplitValue -- 提取节点文本值
    FROM @Xml.nodes('/root/item') T(c) -- 定位到所有item节点
    WHERE T.c.value('.', 'NVARCHAR(MAX)') <> ''; -- 过滤空值(避免首尾|或连续|导致的空元素)

    RETURN;
END;
GO

 declare @id int =124;
 -- 1. 定义字符串变量(若已定义可忽略)
--化料入库DECLARE @StrWithPipe NVARCHAR(MAX) = N'C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370224A0036|C370224A0036|C370224A0036|C370224A0036|C370224A0036|C370224A0036|C370224A0036|C370224A0036|C370224A0036|C370224A0036|C370224A0036|C370225A0035|C370225A0035|C370225A0035|C370225A0035|C370225A0035|C370225A0035|C370225A0035|C370225A0035|C370225A0035|C370225A0035';
--蓝皮领料
--DECLARE @StrWithPipe NVARCHAR(MAX) = N'C370225A0070|C370225A0070|C370225A0070|C370224A0036|C370224A0036|C370224A0036|C370224A0036|C370225A0035|C370225A0035|C370225A0035'

--水场化料领料
--DECLARE @StrWithPipe NVARCHAR(MAX) = N'C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370225A0070|C370224A0036|C370224A0036|C370224A0036|C370224A0036|C370224A0036|C370224A0036|C370224A0036|C370224A0036|C370224A0036|C370224A0036|C370224A0036|C370224A0036|C370224A0036|C370224A0036|C370224A0036|C370224A0036|C370224A0036|C370224A0036|C370224A0036|C370224A0036|C370224A0036|C370224A0036|C370224A0036|C370224A0036|C370224A0036|C370224A0036|C370224A0036|C370224A0036|C370224A0036|C370224A0036|C370224A0036|C370224A0036|C370225A0035|C370225A0035|C370225A0035|C370225A0035|C370225A0035|C370225A0035|C370225A0035|C370225A0035|C370225A0035|C370225A0035|C370225A0035|C370225A0035|C370225A0035|C370225A0035|C370225A0035|C370225A0035|C370225A0035|C370225A0035|C370225A0035|C370225A0035|C370225A0035|C370225A0035|C370225A0035|C370225A0035|C370225A0035|C370225A0035|C370225A0035|C370225A0035|C370225A0035|C370225A0035|C370225A0035|C370225A0035|C370225A0035|C370225A0035|C370225A0035|C370225A0035'

--涂饰化料领料
DECLARE @StrWithPipe NVARCHAR(MAX) = N'2025-08-13|2025-08-13|2025-08-13|2025-08-14|2025-08-14|2025-08-14|2025-08-15|2025-08-15|2025-08-15|2025-08-16|2025-08-16|2025-08-16|2025-08-01|2025-08-01|2025-08-01|2025-08-01|2025-08-01|2025-08-01|2025-08-01|2025-08-01|2025-08-01|2025-08-01|2025-08-01|2025-08-01'

-- 2. 声明变量:存储遍历的当前值、游标
DECLARE @CurrentValue NVARCHAR(MAX); -- 存储每次遍历取出的值
DECLARE MyCursor CURSOR FOR -- 声明游标,指向拆分后的结果表
    SELECT SplitValue 
    FROM dbo.fn_SplitByPipe(@StrWithPipe); -- 调用自定义函数拆分字符串

-- 3. 打开游标
OPEN MyCursor;

-- 4. 从游标中取第一条值
FETCH NEXT FROM MyCursor INTO @CurrentValue;

-- 5. 循环遍历:只要能取到值(@@FETCH_STATUS=0表示成功),就继续执行
WHILE @@FETCH_STATUS = 0
BEGIN
    -- 处理当前值(此处示例为打印,实际可替换为业务逻辑:插入表、更新数据等)
	--FPdOrderNo  FBillNo
    PRINT '当前取出的值:' + @CurrentValue;
	update t_ProductMaterialInOut  set FDate=@CurrentValue where id=@id and FormId='涂饰化料领料'
	set @id=@id+1;
	--insert into t_MaterialInOutDetailed (FormId) values ('涂饰化料领料');
	
    -- 取下一条值,继续循环
    FETCH NEXT FROM MyCursor INTO @CurrentValue;
END;

-- 6. 关闭并释放游标(必须执行,否则占用资源)
CLOSE MyCursor;
DEALLOCATE MyCursor;

2、第二种方式,在Excel表格中使用语句,生成所需要的语句

=CONCAT("insert into table values('",C2,"','",D2,"')")

语句上可以修改成和数据库一致的语句,复制所有语句去执行就可以了

相关推荐
王的宝库6 分钟前
【MySQL】主从复制原理详解:从 Binlog 到数据一致性
数据库·mysql
Vect__7 分钟前
MySQL基本认知、库和表的操作
数据库·mysql
cyber_两只龙宝21 分钟前
【Oracle】Oracle之DQL中SELECT的基础使用
linux·运维·服务器·数据库·云原生·oracle
老苏畅谈运维22 分钟前
Oracle 在线表重定义:将非分区表转换为分区表的最佳实践
数据库·oracle
treacle田26 分钟前
达梦数据库-达梦数据库中link链接访问oracle 19c/11g-记录总结
数据库·oracle·达梦 link访问oracle
萌兰三太子29 分钟前
RAG 向量数据库设计指南:从入门到生产
数据库·oracle
TDengine (老段)1 小时前
中原油田引入时序数据库 TDengine:写入性能提升、存储成本下降 85%
大数据·数据库·人工智能·时序数据库·tdengine·涛思数据
IT邦德1 小时前
Oracle 26ai搭建ADG Far Sync日志备库
数据库·oracle
Crazy CodeCrafter1 小时前
现在做服装,实体和电商怎么选?
大数据·数据库·人工智能·微信·开源软件·零售
一江寒逸1 小时前
零基础从入门到精通MongoDB(下篇):进阶精通篇——吃透高级查询、事务、索引优化与集群架构,成为MongoDB实战高手
数据库·mongodb·架构