ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 673|回复: 5

[分享] 从Excel自动生成SQL CREATE TABLE及INSERT语句的自定义函数

[复制链接]

TA的精华主题

TA的得分主题

发表于 2023-7-4 15:40 | 显示全部楼层 |阅读模式
本帖最后由 ericxzhou 于 2023-7-4 16:57 编辑

Excel ADO 毕竟没有专业SQL软件强大,我写了一个自定义函数,可以根据Excel表格自动生成建表语句,供参考:
  1. Function SQLCTable(ByVal rng As Range, ByVal tblName As String) As String
  2. 'rng为表的范围包含表头
  3. 'tblName为表名,用双引号包围
  4.     Dim i%, j%, arr, str$, str1$, str2$
  5.     arr = rng
  6.     For i = 1 To UBound(arr, 2)
  7.         str1 = str1 & "," & arr(1, i) & typeJudge(arr(2, i))
  8.         '需确保表头下第一行都有数据,第一行如为小数类型小数点后需有数字,否则无法判断列的数据类型
  9.     Next
  10.     str1 = "CREATE TABLE " & tblName & " (" & Right(str1, Len(str1) - 1) & ");" & Chr(10)
  11.     For i = 2 To UBound(arr)
  12.         For j = 1 To UBound(arr, 2)
  13.             Select Case VarType(arr(i, j))
  14.                 Case 7
  15.                     str = str & "," & "'" & Format(arr(i, j), "yyyy-m-d") & "'"
  16.                     '注意SQL存储日期数据的格式,不能用#号包围
  17.                 Case 8
  18.                     str = str & "," & "'" & arr(i, j) & "'"
  19.                 Case 0, 1, 10
  20.                     str = str & ",NULL"
  21.                     '如需改为0,需判断字段类型,否则会发生插入不匹配报错
  22.                 Case 2, 3, 4, 5, 6
  23.                     str = str & "," & arr(i, j)
  24.                 Case Else
  25.                     str = str & "," & "'" & arr(i, j) & "'"
  26.             End Select
  27.         Next
  28.         str2 = str2 & ")," & Chr(10) & "(" & Right(str, Len(str) - 1)
  29.         str = ""
  30.     Next
  31.     SQLCTable = str1 & "INSERT INTO " & tblName & " VALUES " & Right(str2, Len(str2) - 2) & ");"
  32. End Function

  33. Function typeJudge(ByVal inputData As Variant) As String
  34.     Select Case VarType(inputData)
  35.         Case 7
  36.             typeJudge = " DATE"
  37.         Case 8
  38.             typeJudge = " VARCHAR(100)"
  39.             '100为最大长度,如不够可调
  40.         Case 2, 3, 4, 5
  41.             If Int(inputData) = inputData Then
  42.                 typeJudge = " BIGINT"
  43.             Else
  44.                 typeJudge = " DOUBLE"
  45.             End If
  46.         Case Else
  47.             typeJudge = " VARCHAR(100)"
  48.         End Select
  49. End Function
复制代码




SQL从Excel自动生成CREATE TABLE语句1.zip

20.23 KB, 下载次数: 45

增加示例文件

评分

2

查看全部评分

TA的精华主题

TA的得分主题

发表于 2023-7-4 16:00 | 显示全部楼层
看着很牛的样子,不会用

TA的精华主题

TA的得分主题

发表于 2023-7-4 16:31 | 显示全部楼层
上个附件,来个实例呗

TA的精华主题

TA的得分主题

 楼主| 发表于 2023-7-4 16:58 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2023-7-5 01:52 来自手机 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
之前写过类似的,可以在access,sqlserver,mysql
里面用,支持分享。

TA的精华主题

TA的得分主题

发表于 2023-7-5 08:17 | 显示全部楼层
很好,但在Excel中还是少用SQL,毕竟SQL是专业的
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-11-16 22:41 , Processed in 0.033182 second(s), 12 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表