excel 列名是数据表 的字段名 ,单元格的值 是数据表对应字段的值,生成sql插入语句

  1. 在 Excel 中,按 Alt + F11 打开 VBA 编辑器。
  2. 在菜单栏选择 插入 -> 模块,在新模块中粘贴以下代码。

VBA 代码

vbnet 复制代码
Sub GenerateSQLInsertStatementsToFile()
    Dim ws As Worksheet
    Dim lastRow As Long, lastCol As Long, i As Long, j As Long
    Dim sql As String, colNames As String, values As String
    Dim tableName As String
    Dim cellValue As String
    Dim filePath As String
    Dim fileNum As Integer

    ' 设置工作表
    Set ws = ActiveSheet  ' 使用当前活动的工作表
    tableName = "your_table_name"  ' 设置你的数据库表名
    filePath = "D:\file.txt"  ' 设置文件路径

    ' 打开文件
    fileNum = FreeFile()
    Open filePath For Output As #fileNum

    ' 获取数据范围
    lastRow = ws.Cells(ws.Rows.Count, 1).End(xlUp).Row
    lastCol = ws.Cells(1, ws.Columns.Count).End(xlToLeft).Column

    ' 构建列名字符串
    For j = 1 To lastCol
        If j > 1 Then colNames = colNames & ", "
        colNames = colNames & "[" & ws.Cells(1, j).Value & "]"
    Next j

    ' 遍历每一行
    For i = 2 To lastRow
        values = ""
        
        ' 遍历每一列
        For j = 1 To lastCol
            If j > 1 Then values = values & ", "
            
            ' 处理单引号以适应 SQL 语法
            cellValue = Replace(ws.Cells(i, j).Value, "'", "''")
            
            ' 值
            If IsNumeric(cellValue) Then
                values = values & cellValue
            Else
                values = values & "'" & cellValue & "'"
            End If
        Next j
        
        ' 构建 SQL 语句
        sql = "INSERT INTO " & tableName & " (" & colNames & ") VALUES (" & values & ");"
        
        ' 写入文件
        Print #fileNum, sql
    Next i

    ' 关闭文件
    Close #fileNum
End Sub

Excel 并按 Alt + F8,选择 GenerateSQLInsertStatementsToFile,然后点击 运行

相关推荐
倔强的石头_1 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
唐青枫1 天前
Java JDBC 实战指南:从 Connection 到事务和连接池
java
一个做软件开发的牛马1 天前
MyBatis-Plus 从零实战:完整搭建可运行 Demo,BaseMapper 零 SQL、Wrapper 条件构造、分页插件与代码生成器详解
java·后端
用户3721574261351 天前
Java 处理 PDF 图片:提取 PDF 中的图片,并压缩 PDF 图片体积
java
用户3721574261351 天前
Java 打印 Word 文档:从基础打印到高级设置
java
冬奇Lab2 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
用户3521802454752 天前
当 Prompt 学会"热更新":Spring Boot × Nacos3 AI 实战
java·spring boot·ai编程
东坡白菜2 天前
破局全栈:一个前端开发的Java入门实战记录(1)
java·全栈
唐青枫2 天前
Java Tomcat 实战指南:从 Servlet 容器到 Spring Boot 部署
java
wsaaaqqq2 天前
roudan:自由选择实体、灵活操作数据、快速写入数据库的 Java 框架
java