开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 6700|回复: 8
收起左侧

[其它] SQL语句更新、插入、指定条件更新语句创建代码,在mysql8.0中测试通过

[复制链接]
发表于 2020-8-31 23:39:54 | 显示全部楼层 |阅读模式   四川省成都市
  
子程序名返回值类型公开备 注
记录集到数组 
参数名类 型参考可空数组备 注
记录集句柄整数型获取完成后自动释放记录集
通用数组格式文本型提供数组变量,返回二维通用数组格式
变量名类 型静态数组备 注
计次变量1整数型 
计次变量2整数型 
记录集记录行数整数型 
记录集字段列数整数型 
当前值文本型 
记录集记录行数 = 取记录集行数 (记录集句柄)
记录集字段列数 = 取字段总数 (记录集句柄)
如果真 (记录集记录行数 ≤ 0 记录集字段列数 ≤ 0)
返回 ()
重定义数组 (通用数组格式, 假, 记录集记录行数 + 1, 记录集字段列数)  ' 第一行为字段名
到首行 (记录集句柄)
计次循环首 (记录集记录行数 + 1, 计次变量1)
计次循环首 (记录集字段列数, 计次变量2)
如果 (计次变量1 = 1)
序号到字段名 (记录集句柄, 计次变量2 - 1, 当前值)
读字段值 (记录集句柄, 计次变量2 - 1, 当前值)  ' 字段索引从0开始
通用数组格式 [计次变量1] [计次变量2] = 当前值
计次循环尾 ()
如果真 (计次变量1 ≠ 1)
到下一行 (记录集句柄)

计次循环尾 ()
调试输出 (“记录集到数组”, 记录集句柄, 通用数组格式)
释放记录集 (记录集句柄)
子程序名返回值类型公开备 注
数组到更新SQL语句文本型 UPDATE,第一个字段必须为主键唯一值ID
参数名类 型参考可空数组备 注
数据表名文本型
更新数据数组文本型通用数组格式,第一行为字段名,第一个字段必须为主键唯一值ID
变量名类 型静态数组备 注
局_记录行数整数型 
局_字段列数整数型 
SQL语句_分段语句文本型0
计次变量1整数型 
计次变量2整数型 
SQL语句_限制条件文本型 
计次变量3整数型 
计次变量4整数型 
SQL语句_分段语句合并文本型 
计次变量5整数型 
SQL语句文本型 
局_记录行数 = 取数组下标 (更新数据数组, 1)
局_字段列数 = 取数组下标 (更新数据数组, 2)
如果真 (局_记录行数 < 2 局_字段列数 < 2)
返回 (“”)
重定义数组 (SQL语句_分段语句, 假, 局_字段列数 - 1)
计次循环首 (局_记录行数 - 1, 计次变量1)  ' 第一行为字段名
' -----------------------------字段名---------------ID值----写入值--ID值----写入值--
' UPDATE 0eb00750a7c5f361 SET 清标工程量=CASE ID WHEN 1 THEN 100 WHEN 2 THEN 200 END,清标综合单价=CASE ID WHEN 1 THEN 300 WHEN 2 THEN 400 END WHERE ID IN(1,2)
如果 (计次变量1 = 1)
计次循环首 (局_字段列数 - 1, 计次变量2)
SQL语句_分段语句 [计次变量2] = 更新数据数组 [计次变量1] [计次变量2 + 1]“=CASE ID WHEN ” + 更新数据数组 [计次变量1 + 1] [1]“ THEN '” + 更新数据数组 [计次变量1 + 1] [计次变量2 + 1]
计次循环尾 ()
SQL语句_限制条件 = “ WHERE ID IN(” + 更新数据数组 [计次变量1 + 1] [1]
计次循环首 (局_字段列数 - 1, 计次变量3)
SQL语句_分段语句 [计次变量3] = SQL语句_分段语句 [计次变量3]“' WHEN ” + 更新数据数组 [计次变量1 + 1] [1]“ THEN '” + 更新数据数组 [计次变量1 + 1] [计次变量3 + 1]
计次循环尾 ()
SQL语句_限制条件 = SQL语句_限制条件 + “,” + 更新数据数组 [计次变量1 + 1] [1]

计次循环尾 ()
计次循环首 (局_字段列数 - 1, 计次变量4)
SQL语句_分段语句 [计次变量4] = SQL语句_分段语句 [计次变量4]“' END”
计次循环尾 ()
SQL语句_限制条件 = SQL语句_限制条件 + “)”
计次循环首 (局_字段列数 - 1, 计次变量5)
如果 (计次变量5 = 1)
SQL语句_分段语句合并 = SQL语句_分段语句 [计次变量5]
SQL语句_分段语句合并 = SQL语句_分段语句合并 + “,” + SQL语句_分段语句 [计次变量5]

计次循环尾 ()
SQL语句 = “UPDATE ” + 数据表名 + “ SET ” + SQL语句_分段语句合并 + SQL语句_限制条件
调试输出 (SQL语句)
返回 (SQL语句)
子程序名返回值类型公开备 注
数组到更新SQL语句_使用指定字段条件文本型 UPDATE,第一个字段必须为“指定字段条件”的值
参数名类 型参考可空数组备 注
指定字段条件文本型
数据表名文本型
更新数据数组文本型通用数组格式,第一行为字段名,第一个字段必须为“指定字段条件”的值
变量名类 型静态数组备 注
局_记录行数整数型 
局_字段列数整数型 
SQL语句_分段语句文本型0
计次变量1整数型 
计次变量2整数型 
SQL语句_限制条件文本型 
计次变量3整数型 
计次变量4整数型 
SQL语句_分段语句合并文本型 
计次变量5整数型 
SQL语句文本型 
局_记录行数 = 取数组下标 (更新数据数组, 1)
局_字段列数 = 取数组下标 (更新数据数组, 2)
如果真 (局_记录行数 < 2 局_字段列数 < 2)
返回 (“”)
重定义数组 (SQL语句_分段语句, 假, 局_字段列数 - 1)
计次循环首 (局_记录行数 - 1, 计次变量1)  ' 第一行为字段名
' -----------------------------字段名---------------ID值----写入值--ID值----写入值--
' UPDATE 0eb00750a7c5f361 SET 清标工程量=CASE ID WHEN 1 THEN 100 WHEN 2 THEN 200 END,清标综合单价=CASE ID WHEN 1 THEN 300 WHEN 2 THEN 400 END WHERE ID IN(1,2)
如果 (计次变量1 = 1)
计次循环首 (局_字段列数 - 1, 计次变量2)
SQL语句_分段语句 [计次变量2] = 更新数据数组 [计次变量1] [计次变量2 + 1]“=CASE ” + 指定字段条件 + “ WHEN ” + 更新数据数组 [计次变量1 + 1] [1]“ THEN '” + 更新数据数组 [计次变量1 + 1] [计次变量2 + 1]
计次循环尾 ()
SQL语句_限制条件 = “ WHERE ” + 指定字段条件 + “ IN(” + 更新数据数组 [计次变量1 + 1] [1]
计次循环首 (局_字段列数 - 1, 计次变量3)
SQL语句_分段语句 [计次变量3] = SQL语句_分段语句 [计次变量3]“' WHEN ” + 更新数据数组 [计次变量1 + 1] [1]“ THEN '” + 更新数据数组 [计次变量1 + 1] [计次变量3 + 1]
计次循环尾 ()
SQL语句_限制条件 = SQL语句_限制条件 + “,” + 更新数据数组 [计次变量1 + 1] [1]

计次循环尾 ()
计次循环首 (局_字段列数 - 1, 计次变量4)
SQL语句_分段语句 [计次变量4] = SQL语句_分段语句 [计次变量4]“' END”
计次循环尾 ()
SQL语句_限制条件 = SQL语句_限制条件 + “)”
计次循环首 (局_字段列数 - 1, 计次变量5)
如果 (计次变量5 = 1)
SQL语句_分段语句合并 = SQL语句_分段语句 [计次变量5]
SQL语句_分段语句合并 = SQL语句_分段语句合并 + “,” + SQL语句_分段语句 [计次变量5]

计次循环尾 ()
SQL语句 = “UPDATE ” + 数据表名 + “ SET ” + SQL语句_分段语句合并 + SQL语句_限制条件
调试输出 (SQL语句)
返回 (SQL语句)
子程序名返回值类型公开备 注
数组到插入SQL语句文本型 INSERT
参数名类 型参考可空数组备 注
数据表名文本型
插入数据数组文本型通用数组格式,第一行为字段名,不得包含已经存在的ID值,不然会插入失败。
变量名类 型静态数组备 注
记录行数整数型 
字段列数整数型 
SQL语句字段区域文本型 
计次变量2整数型 
计次变量1整数型 
计次变量3整数型 
SQL语句数据区域文本型 
SQL语句文本型 
计次变量4整数型 
记录行数 = 取数组下标 (插入数据数组, 1)
字段列数 = 取数组下标 (插入数据数组, 2)
' 1、' 字段区域SQL处理
SQL语句字段区域 = “”
计次循环首 (字段列数, 计次变量2)  ' 第一行为字段行
' SQL语句字段区域 = “` (`项目编码`, `项目名称`, `计量单位`, `投标工程量`, `投标综合单价`, `投标合价金额`, `数据项类型`) ”
如果 (计次变量2 = 1)
SQL语句字段区域 = “` (`” + 插入数据数组 [1] [计次变量2]
SQL语句字段区域 = SQL语句字段区域 + “`, `” + 插入数据数组 [1] [计次变量2]

计次循环尾 ()
SQL语句字段区域 = SQL语句字段区域 + “`) ”
调试输出 (SQL语句字段区域)
' 2、数据区SQL处理
计次循环首 (记录行数 - 1, 计次变量1)  ' 第一行为字段名
如果 (计次变量1 = 1)
' 2、数据区SQL处理
计次循环首 (字段列数, 计次变量3)
如果 (计次变量3 = 1)
SQL语句数据区域 = “('”字符转义_sql (插入数据数组 [计次变量1 + 1] [计次变量3])
SQL语句数据区域 = SQL语句数据区域 + “', '”字符转义_sql (插入数据数组 [计次变量1 + 1] [计次变量3])

计次循环尾 ()
SQL语句数据区域 = SQL语句数据区域 + “')”
' 调试输出 (SQL语句数据区域)
' 3、首字段区域数据区合并
SQL语句 = “INSERT INTO `”字符转义_sql (数据表名) + SQL语句字段区域 + “VALUES ” + SQL语句数据区域
' 调试输出 (SQL语句)
' 2、数据区SQL处理
计次循环首 (字段列数, 计次变量4)
如果 (计次变量4 = 1)
SQL语句数据区域 = “('”字符转义_sql (插入数据数组 [计次变量1 + 1] [计次变量4])
SQL语句数据区域 = SQL语句数据区域 + “', '”字符转义_sql (插入数据数组 [计次变量1 + 1] [计次变量4])

计次循环尾 ()
SQL语句数据区域 = SQL语句数据区域 + “')”
' 调试输出 (SQL语句数据区域)
' 4、中间数据区合并,SQl语句累加
SQL语句 = SQL语句 + “,” + SQL语句数据区域
' 调试输出 (SQL语句)

计次循环尾 ()
调试输出 (SQL语句)
返回 (SQL语句)


i支持库列表   支持库注释   
mysqlMySql支持库
spec特殊功能支持库


发表于 2021-3-21 08:59:28 高大上手机用户 | 显示全部楼层   上海市上海市
支持开源!谢谢分享!
回复 支持 反对

使用道具 举报

发表于 2021-1-29 18:05:43 | 显示全部楼层   上海市上海市
插个眼,感谢分享
回复 支持 反对

使用道具 举报

结帖率:75% (3/4)
发表于 2020-11-4 20:07:19 | 显示全部楼层   四川省成都市
学习了  感谢分享  
回复 支持 反对

使用道具 举报

结帖率:100% (2/2)

签到天数: 13 天

发表于 2020-9-6 15:15:11 | 显示全部楼层   广西壮族自治区桂林市
插个眼.回头再来学
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-9-2 12:30:36 | 显示全部楼层   四川省成都市
bbs592 发表于 2020-9-1 20:10
字符转义_sql.............................能写例子吗?
  1. .版本 2

  2. .子程序 字符转义_sql, 文本型, 公开
  3. .参数 需要判断转义的文本, 文本型, 参考
  4. .局部变量 必须转义的字符组, 文本型, , "0"
  5. .局部变量 计次变量1, 整数型

  6. ' 添加需要转义的字符
  7. 加入成员 (必须转义的字符组, 字符 (92))  ' /,必须在第一个
  8. 加入成员 (必须转义的字符组, 字符 (39))  ' '
  9. 加入成员 (必须转义的字符组, 字符 (34))  ' "

  10. .计次循环首 (取数组成员数 (必须转义的字符组), 计次变量1)
  11.     需要判断转义的文本 = 子文本替换 (需要判断转义的文本, 必须转义的字符组 [计次变量1], “\” + 必须转义的字符组 [计次变量1], , , 真)
  12. .计次循环尾 ()
  13. 返回 (需要判断转义的文本)

复制代码
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-9-2 12:29:59 | 显示全部楼层   四川省成都市
bbs592 发表于 2020-9-1 20:10
字符转义_sql.............................能写例子吗?
  
子程序名返回值类型公开备 注
字符转义_sql文本型 
参数名类 型参考可空数组备 注
需要判断转义的文本文本型
变量名类 型静态数组备 注
必须转义的字符组文本型0
计次变量1整数型 
' 添加需要转义的字符
加入成员 (必须转义的字符组, 字符 (92))  ' /,必须在第一个
加入成员 (必须转义的字符组, 字符 (39))  ' '
加入成员 (必须转义的字符组, 字符 (34))  ' "
计次循环首 (取数组成员数 (必须转义的字符组), 计次变量1)
需要判断转义的文本 = 子文本替换 (需要判断转义的文本, 必须转义的字符组 [计次变量1], “\” + 必须转义的字符组 [计次变量1], , , )
计次循环尾 ()
返回 (需要判断转义的文本)

回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-9-2 12:29:32 | 显示全部楼层   四川省成都市
bbs592 发表于 2020-9-1 20:10
字符转义_sql.............................能写例子吗?
  
子程序名返回值类型公开备 注
字符转义_sql文本型 
参数名类 型参考可空数组备 注
需要判断转义的文本文本型
变量名类 型静态数组备 注
必须转义的字符组文本型0
计次变量1整数型 
' 添加需要转义的字符
加入成员 (必须转义的字符组, 字符 (92))  ' /,必须在第一个
加入成员 (必须转义的字符组, 字符 (39))  ' '
加入成员 (必须转义的字符组, 字符 (34))  ' "
计次循环首 (取数组成员数 (必须转义的字符组), 计次变量1)
需要判断转义的文本 = 子文本替换 (需要判断转义的文本, 必须转义的字符组 [计次变量1], “\” + 必须转义的字符组 [计次变量1], , , )
计次循环尾 ()
返回 (需要判断转义的文本)

回复 支持 反对

使用道具 举报

结帖率:98% (63/64)
发表于 2020-9-1 20:10:33 | 显示全部楼层   湖南省郴州市
字符转义_sql.............................能写例子吗?
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 793400750,邮箱:wp@125.la
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

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