ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[原创] 池盛龙的开发经验分享:写SQL插入更新语句,如何简洁代码,如何提高开发效率。

[复制链接]

TA的精华主题

TA的得分主题

发表于 2020-11-8 22:41 | 显示全部楼层 |阅读模式
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
是否你平时写代码时,惯用手法是新增信息时写一段插入语句。如下图这样。或者是一行带过,有长又臭。 image.png
是否写完插入语句后,再像下面这样,写一遍插入语句
image.png
结果,维护起来时,内容多时,如果要修改,要去找第几行位置去修改语句。这种情况不知道大家有没有
起码我刚开始时,是这样写的。后来代码写多了,我感觉很费事,维护也不是很高效,所以我写一个函数,自创一个独特到方法来,偷懒
使用规范:
文本类型写法: 字段标题{W变量内容}|     如: "编号{W" & TextBox1.Text & "}|"
数值类型写法: 字段标题{S变量内容}|     如: "编号{S" & TextBox1.Text & "}|"
效果:
image.png
调用方法:
SQl = SQL_CHISHENGLONG("插入", VF, "客户档案") '生成插入语句
SQl = SQL_CHISHENGLONG("更新", VF, "客户档案") '生成更新语句
  1. Function SQL_CHISHENGLONG(ByVal A As String, ByVal B As String, ByVal C As String) '自动生成插入,更新语句
  2.        SQL_CHISHENGLONG = ""
  3.         Dim SQ1 As  String
  4.         Dim SQ2 As  String
  5.         Select Case A
  6.             Case "插入"
  7.                 '解释语句
  8.                 For X As Integer = 0 To UBound(Split(B, "}|")) - 1
  9.                     Dim BT = Split(Split(B, "}|")(X), "{")(0) '标题
  10.                     Dim NR = ""
  11.                     If Split(B, "}|")(X) Like "*{W*" Then '判断是否为文本类型
  12.                         NR = "'" & Split(Split(B, "}|")(X), "{W")(1) & "'" '内容
  13.                     ElseIf Split(B, "}|")(X) Like "*{S*" Then '判断是否为数字类型
  14.                         NR = Split(Split(B, "}|")(X), "{S")(1)  '内容
  15.                     Else

  16.                         Exit Function
  17.                     End If
  18.                     SQ1 = SQ1 & BT & ","
  19.                     SQ2 = SQ2 & NR & ","
  20.                 Next
  21.                 '除去最后逗号
  22.                 SQ1 = Left(SQ1, Len(SQ1) - 1)
  23.                 SQ2 = Left(SQ2, Len(SQ2) - 1)
  24.                 SQL_CHISHENGLONG= "INSERT INTO " & C & " ( " & SQ1 & ")VALUES (" & SQ2 & ")"
  25.             Case "更新"
  26.                 '解释语句
  27.                 For X As Integer = 0 To UBound(Split(B, "}|")) - 1
  28.                     Dim BT = Split(Split(B, "}|")(X), "{")(0) '标题
  29.                     Dim NR = ""
  30.                     If Split(B, "}|")(X) Like "*{W*" Then '判断是否为文本类型
  31.                         NR = "'" & Split(Split(B, "}|")(X), "{W")(1) & "'" '内容
  32.                     ElseIf Split(B, "}|")(X) Like "*{S*" Then '判断是否为数字类型
  33.                         NR = Split(Split(B, "}|")(X), "{S")(1)  '内容
  34.                     Else
  35.                         Exit Function
  36.                     End If
  37.                     SQ1 = SQ1 & BT & "=" & NR & ","
  38.                 Next
  39.                 '除去最后逗号
  40.                 SQ1 = Left(SQ1, Len(SQ1) - 1)
  41.                 SQL_CHISHENGLONG= "UPDATE " & C & " SET " & SQ1
  42.         End Select
  43.     End Function
复制代码
如果对你有帮助请送小鲜花,谢谢大家

评分

2

查看全部评分

TA的精华主题

TA的得分主题

发表于 2020-11-9 02:39 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
另一个开发思路供参考

https://blog.csdn.net/taller_2000/article/details/79394981

评分

3

查看全部评分

TA的精华主题

TA的得分主题

发表于 2020-11-9 13:26 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
本帖最后由 xd3210 于 2020-11-9 13:47 编辑

本人也摸索了一套类似的经验,就是直接读取字段类型,生成sql语句时,根据字段类型来决定字段值前后时否有分隔符或什么样的分隔符

TA的精华主题

TA的得分主题

 楼主| 发表于 2020-11-9 14:28 | 显示全部楼层
xd3210 发表于 2020-11-9 13:26
本人也摸索了一套类似的经验,就是直接读取字段类型,生成sql语句时,根据字段类型来决定字段值前后时否有 ...

也可以, 你这种,只要代码争取写的越少,越清晰就好

TA的精华主题

TA的得分主题

发表于 2020-11-10 09:21 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
taller 发表于 2020-11-9 02:39
另一个开发思路供参考

https://blog.csdn.net/taller_2000/article/details/79394981

不知t版这个方案是否适用较长且复杂的sql语句生成?

TA的精华主题

TA的得分主题

发表于 2020-11-12 17:11 | 显示全部楼层
最近,看楼主的进步帖子分享多了,不禁想在兄弟的地方卖花赞花香一下。
楼主不妨参考一下,看看有没有调整的空间

用类做自定义SQL读取函数及数组转置函数
http://club.excelhome.net/thread-1517858-1-1.html

评分

1

查看全部评分

TA的精华主题

TA的得分主题

 楼主| 发表于 2020-11-12 17:26 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
本帖最后由 池盛龙 于 2020-11-12 17:27 编辑
microyip 发表于 2020-11-12 17:11
最近,看楼主的进步帖子分享多了,不禁想在兄弟的地方卖花赞花香一下。
楼主不妨参考一下,看看有没有调整 ...

你的也很好,我的方法是不要转置,这样查询结果的速度更快,只是多写一个根据标题获取所在列就可以了。因为考虑到,场景不一定全部都要显示全部结果。请看我方法贴做法:http://club.excelhome.net/thread-1562807-1-1.html

TA的精华主题

TA的得分主题

发表于 2020-11-12 17:29 | 显示全部楼层
池盛龙 发表于 2020-11-12 17:26
你的也很好,我的方法是不要转置,这样查询结果的速度更快,只是多写一个根据标题获取所在列就可以了。因 ...

我的建议是做成类,方便调用。提出来,看看你有没有什么可调整的空间而已

TA的精华主题

TA的得分主题

 楼主| 发表于 2020-11-12 17:36 | 显示全部楼层
microyip 发表于 2020-11-12 17:29
我的建议是做成类,方便调用。提出来,看看你有没有什么可调整的空间而已

你是说你的方法吗

TA的精华主题

TA的得分主题

发表于 2022-4-14 00:06 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
taller 发表于 2020-11-9 02:39
另一个开发思路供参考

https://blog.csdn.net/taller_2000/article/details/79394981

支持啊,好资料啊,提供另一种思路奥
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-6-16 09:46 , Processed in 0.035590 second(s), 11 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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