VBA 批量生成 SQL

本文简单介绍一下用 VBA 来批量生成 SQL。

在平常工作中,有可能遇到这样的场景,Excel 里面的 N 多个数据需要导入到数据库中,如果人工去拼接 SQL 会很麻烦,这时候写个简单的 VBA 函数就可以搞定了。

案例

假设我们有一个表,如下所示,需要导入到 MySQL 数据库中的一张表里面。
Excel

假设我们要执行的 SQL 是:

insert into vbaTable (name, age) values ('xxx', 10);

这时候使用 VBA 就可以很容易就做到

开发 VBA 函数

在 Excel 中点击宏,进行编码,代码如下所示:

Const startRow = 1
Const endRow = 26
Const startCol = 1
Const endCol = 2

Sub VBAdemo()
    Set s = ThisWorkbook.Sheets("Sheet1")

    For i = startRow To endRow Step 1
        Dim strSql As String
        strSql = "insert into vbaTable (name, age) values ('{1}', {2});"

        For j = startCol To endCol Step 1
            Dim value As String
            value = Trim(s.Cells(i, j).Text)
            strSql = Replace(strSql, "{" & j & "}", value)
        Next

        Debug.Print strSql
    Next

End Sub

点击运行,即可得到结果

这里写图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值