开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

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


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

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

查看: 772|回复: 3
打印 上一主题 下一主题
收起左侧

[易语言] Access数据同一个SQLcha询语句,连读多次cha询后会cha询失败!

[复制链接]
结帖率:0% (0/1)
跳转到指定楼层
楼主
发表于 2023-3-6 17:58:37 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式   甘肃省天水市
10精币
同一个sql语句,用判断循环的命令连续对同一个数据表里面的不同行的数据进行查询,循环查询15次之后就查询失败了,前面15次都是成功的,第16次开始就连续查询失败。试了好多次都是这样,
软件关了重新打开又是可以查询15次就不行了,跳过报错的那个查询命令时,下一个查询命令也会查询失败!  总之只要查询15次循环,第16次查询不管是查询Access里面哪个数据,都是查询失败。
代码截图贴在下面了,哪个大佬能指导下吗?
备注:写这个的目的是想把Access数据库里面的数据,通过始终循环查询监控,把Access数据库的内容都传到mysql中!
  
子程序名返回值类型公开备 注
Access数据库循环采集  
变量名类 型静态数组备 注
局_SQL文本型 
局_返回数据类_json 
局_起始时间文本型 
局_结束时间文本型 
数据编号文本型 
设备编号文本型 
测量值小数型 
n整数型 
记录数量整数型 
客户代码文本型 
芯片型号文本型 
测量时间日期时间型 
操作员编号文本型 
测量标准文本型 
芯片厚度文本型 
判断结果文本型 
测量标准查询编号整数型 
FLT上限文本型 
FLT下限文本型 
局_addtime文本型 
局_user文本型 
文本型变量文本型 
流程卡号文本型 
压焊图号文本型 
工号文本型 
局_记录集句柄整数型 
局_MeasureStander_Item句柄整数型 
局_Customer句柄整数型 
测量值查询编号整数型 
局_MeasureData句柄整数型 
局_code文本型 
flt1文本型 
flt2文本型 
flt3文本型 
flt4文本型 
flt最小值文本型 
flt最大值文本型 
flt平均值文本型 
检测结果文本型 
A文本型 
局_查询异常时间文本型 
数据库重连 ()  ' 'mysql数据库重连
Access数据库重连 ()  ' 'Access数据库重连
' ''''' ''''' ''''' ' ''''' ''''''''' ''''''''' ''''''''' '''''''' 基础表Customer查询开始 ''''''' ''''''' ''''' ''''' ''''' ''''' ''''' ''''' ''''' '''''
局_code = 时间_到时间戳 (取现行时间 (), 真, )
取上次采集结束时间 ()
' 局_起始时间 = 到文本 (时间_格式化 (全_上次采集结束时间, “yyyy/M/d”, “ hh:mm:ss”, 真, ))
' 局_结束时间 = 到文本 (时间_格式化 (增减时间 (全_上次采集结束时间, #分钟, 2), “yyyy/M/d”, “ hh:mm:ss”, 真, ))
局_起始时间 = 到文本 (时间_格式化 (增减时间 (取现行时间 (), #年份, -5), “yyyy/M/d”, “ hh:mm:ss”, 真, ))
局_结束时间 = 到文本 (时间_格式化 (取现行时间 (), “yyyy/M/d”, “ hh:mm:ss”, 真, ))
调试输出 (局_起始时间)
调试输出 (局_结束时间)
' *** 缩略程序块 ***
局_Customer句柄 = Access.查询 (“Customer”, “_DateTime”, 假, “select * from Customer where `_DateTime` BETWEEN #” + 局_起始时间 + “# AND #” + 局_结束时间 + “#”)
调试输出 (局_Customer句柄)
如果真 (局_Customer句柄 = 0)
信息框 (“数据表Customer查询失败,请反馈工艺工程处理!”, 0, , )
结束 ()
时钟_数据读取.时钟周期 = 0
外部数据库1.到首记录 (局_Customer句柄)
判断循环首 (外部数据库1.尾记录后 (局_Customer句柄))
流程卡号 = 外部数据库1. (局_Customer句柄, “_ID”)
压焊图号 = 外部数据库1. (局_Customer句柄, “_MapId”)
芯片型号 = 外部数据库1. (局_Customer句柄, “_ChipId”)
客户代码 = 外部数据库1. (局_Customer句柄, “_CustomerId”)
设备编号 = 外部数据库1. (局_Customer句柄, “_EquId”)
测量时间 = 外部数据库1. (局_Customer句柄, “_DateTime”)
操作员编号 = 外部数据库1. (局_Customer句柄, “_UserId”)
测量标准查询编号 = 外部数据库1. (局_Customer句柄, “_Stander_Id”)
测量值查询编号 = 外部数据库1. (局_Customer句柄, “ID”)
编辑框_log.加入文本 (“流程卡号= ” + 流程卡号 + #换行符 )
编辑框_log.加入文本 (“压焊图号= ” + 压焊图号 + #换行符 )
编辑框_log.加入文本 (“芯片型号= ” + 芯片型号 + #换行符 )
编辑框_log.加入文本 (“客户代码= ” + 客户代码 + #换行符 )
编辑框_log.加入文本 (“设备编号= ” + 设备编号 + #换行符 )
编辑框_log.加入文本 (“测量时间= ”到文本 (测量时间)#换行符 )
编辑框_log.加入文本 (“操作员编号= ” + 操作员编号 + #换行符 )
编辑框_log.加入文本 (“测量标准查询编号= ”到文本 (测量标准查询编号)#换行符 )
编辑框_log.加入文本 (“测量值查询编号= ”到文本 (测量值查询编号)#换行符 )
' ''''' ''''' ''''' '''' ''''''''' ''''''''' '''''''' 根据表Customer中_Stander_Id字段查询测量标准 ''''''' ''''''' ''''' ''''' '''''  ''''' ''''' ''''' '''''
局_MeasureStander_Item句柄 = Access.查询 (“MeasureStander_Item”, “_Stander_Id”, 假, “select * from MeasureStander_Item where `_Stander_Id` = ”到文本 (测量标准查询编号))
如果真 (局_MeasureStander_Item句柄 = 0)
信息框 (“数据表MeasureStander_Item查询失败,请反馈工艺工程处理!”, 0, , )
结束 ()
外部数据库1.到首记录 (局_MeasureStander_Item句柄)
测量标准 = 外部数据库1. (局_MeasureStander_Item句柄, “_Stander_Item_Name”)
FLT上限 = 外部数据库1. (局_MeasureStander_Item句柄, “_Plus”)
FLT下限 = 外部数据库1. (局_MeasureStander_Item句柄, “_Minus”)
编辑框_log.加入文本 (“测量标准= ” + 测量标准 + #换行符 )
编辑框_log.加入文本 (“FLT上限= ” + FLT上限 + #换行符 )
编辑框_log.加入文本 (“FLT下限= ” + FLT下限 + #换行符 )
' ''''' ''''' ''''' '''' ' '''' ' '''''' ' '''''' ' '''''''''' 出错区域,多次运行后查询失败 ''''''' ' '''''' '''''''' ''''' '''''  ''''' ''''' '''''
局_MeasureData句柄 = Access.查询 (“MeasureData”, “_CustomerId”, 假, “select * from MeasureData where `_CustomerId` = ”到文本 (测量值查询编号))
调试输出 (“局_MeasureData句柄 =”到文本 (局_MeasureData句柄))
如果真 (局_MeasureData句柄 = 0)
信息框 (“数据表MeasureData查询失败,请反馈工艺工程处理!”, 0, , )
结束 ()
' ''''' ''''' ''''' '''' '' ' '''''' ' ''''' '''' ' '''''''''' 出错区域,多次运行后查询失败''''''' '' ' '''''''''''' ''''' '''''  ''''' ''''' '''''
' ''''' ''''' ''''' ''''' '''''''' Access后续要输入的内容能查询成功的情况下,已经查询到的数据先存入Mysql,并用唯一码进行标记 ''''''' ''''''' ''''' ''
局_user = 全_操作用户.用户名
局_addtime = 时间_格式化 (取现行时间 (), “yyyy-M-dd ”, “hh:mm:ss”, 真, )
局_code = 到文本 (到数值 (局_code) + 1)
局_SQL = “insert into buyoff_flt (`area`,`kehu`,`liucheng_card`,`yahan_id`,`die_xinghao`,`die_bonder`,`jiance_op`,`jiance_machine`,`jiance_spec`,`addtime`,`flt_down`,`flt_up`,`jiance_time`,`user`,`code`) values ('%s','%s','%s','%s','%s','%s','%s','%s','%s','%s','%s','%s','%s','%s','%s')”
局_SQL = 格式化文本 (局_SQL, 全_操作用户.区域, 客户代码, 流程卡号, 压焊图号, 芯片型号, 设备编号, 操作员编号, 显微镜编号, 测量标准, 局_addtime, FLT下限, FLT上限, 到文本 (测量时间), 局_user, 局_code)
如果真 (全_mysql.方法_开始事务 ())
如果 (全_mysql.方法_执行 (局_SQL))
全_mysql.方法_保存事务 ()
全_mysql.方法_回滚事务 ()
' 信息框 (“数据存储失败!”, 16, , )
编辑框_log.加入文本 (“文件读取成功,但保存至数据库失败---”到文本 (取现行时间 ()) + #换行符 )
返回 ()


' ''''' ''''' ''''' '''' ' '''''''' 将Access中MeasureData表的单个flt测量值通过唯一码循update存入Mysql ''''''' '''''''' ''''' '''''  ''''' ''''' '''''
' *** 缩略程序块 ***
' 局_MeasureData句柄 = Access.查询 (“MeasureData”, “_CustomerId”, 假, “select * from MeasureData where `_CustomerId` like '%” + 到文本 (测量值查询编号) + “%'”)
' 局_MeasureData句柄 = Access.查询 (“MeasureData”, “_CustomerId”, 假, “select * from MeasureData where `_CustomerId` = '” + 到文本 (测量值查询编号) + “'”)
' '''''''' 数字查询时,数值字段两侧不能用单引号
延时 (100)
外部数据库1.到首记录 (局_MeasureData句柄)
n = 0
判断循环首 (外部数据库1.尾记录后 (局_MeasureData句柄))
n = n + 1
测量值 = 外部数据库1. (局_MeasureData句柄, “_MeasureData”)
调试输出 (“测量值= ”到文本 (测量值)#换行符 )
编辑框_log.加入文本 (“测量值flt”到文本 (n)“=”到文本 (测量值)#换行符#换行符 )
局_SQL = “update buyoff_flt set `flt”到文本 (n)“` = '%s' where `code` = '%s'”
局_SQL = 格式化文本 (局_SQL, 到文本 (测量值), 局_code)
调试输出 (局_code)
如果真 (全_mysql.方法_开始事务 ())
判断 (全_mysql.方法_执行 (局_SQL))
全_mysql.方法_保存事务 ()
' 信息框 (“提交成功”, 64, , )
全_mysql.方法_回滚事务 ()
编辑框_log.加入文本 (“文件读取成功,但保存至数据库失败---”到文本 (取现行时间 ()) + #换行符 )
' 返回 ()
信息框 (“提交失败”, 16, , )
延时 (100)

外部数据库1.到后一记录 (局_MeasureData句柄)
判断循环尾 ()
' ''''' ''''' ''''' '''' ''''' '''''''' 通过Mysql中已有数据算最小值,最大值,平均值和判定结论 ''''''' ''''''' ''''' ''''' '''''  ''''' ''''' '''''
延迟 (100)
局_SQL = “select * from buyoff_flt  where `code` = '” + 局_code + “'”
全_mysql.方法_查询 (局_SQL, 局_返回数据)
' 局_数量 = 到数值 (局_返回数据.取通用属性 (“记录数量”, ))
' 调试输出 (“局_数量 =” + 到文本 (局_数量))
flt1 = 局_返回数据.取通用属性 (“数据[0].flt1”, )
flt2 = 局_返回数据.取通用属性 (“数据[0].flt2”, )
flt3 = 局_返回数据.取通用属性 (“数据[0].flt3”, )
flt4 = 局_返回数据.取通用属性 (“数据[0].flt4”, )
加入成员 (集_历史数据, 到数值 (flt1))
加入成员 (集_历史数据, 到数值 (flt2))
加入成员 (集_历史数据, 到数值 (flt3))
加入成员 (集_历史数据, 到数值 (flt4))
数组排序 (集_历史数据, )
flt最小值 = 到文本 (集_历史数据 [1])
flt最大值 = 到文本 (集_历史数据 [取数组成员数 (集_历史数据)])
调试输出 (“最小值是:”到文本 (集_历史数据 [1]), “最大值是:”到文本 (集_历史数据 [取数组成员数 (集_历史数据)]))
flt平均值 = 到文本 (四舍五入 ( (到数值 (flt1)到数值 (flt2)到数值 (flt3)到数值 (flt4)) ÷ 4, 2))
如果 (flt最小值 > FLT下限 flt最大值 < FLT上限)
检测结果 = “OK”
检测结果 = “NO”
删除成员 (集_历史数据, 1, 4)
' ''''' ''''' ''''' '''' '''''



i支持库列表   支持库注释   
spec特殊功能支持库
eAPI应用接口支持库







补充内容 (2023-3-6 18:02):
如果在上面的代码里面再插入点Access的cha询命令,可能还查不了15个循环就报错cha询失败了!

补充内容 (2023-3-6 18:02):
Access数据操作的模块用的论坛大佬分享的:https://125.confly.eu.org/forum.php?mod ... mp;highlight=Access


回答提醒:如果本帖被关闭无法回复,您有更好的答案帮助楼主解决,请发表至 源码区 可获得加分喔。
友情提醒:本版被采纳的主题可在 申请荣誉值 页面申请荣誉值,获得 1点 荣誉值,荣誉值可兑换荣誉会员、终身vip用户组。
快捷通道:申请荣誉值无答案申请取消悬赏投诉有答案未采纳为最佳
结帖率:78% (18/23)

签到天数: 1 天

沙发
发表于 2023-3-6 21:15:22 | 只看该作者   浙江省嘉兴市
要关闭记录集。如果不关闭,15到20次cha询后,读取就为空了。
回复

使用道具 举报

结帖率:0% (0/1)
板凳
 楼主| 发表于 2023-3-7 15:49:09 | 只看该作者   甘肃省天水市
走一回 发表于 2023-3-6 21:15
要关闭记录集。如果不关闭,15到20次cha询后,读取就为空了。

没有用关闭记录集的写法,连记录集组件都没添加。。。
回复

使用道具 举报

结帖率:78% (18/23)

签到天数: 1 天

地板
发表于 2023-3-7 22:42:45 | 只看该作者   浙江省嘉兴市
金B镶钻一炮十万 发表于 2023-3-7 15:49
没有用关闭记录集的写法,连记录集组件都没添加。。。

如果用记录集来cha询的话,也是cha询大概15次就不能cha询了。所以你的问题就是类似的问题,想办法找到。看到了,你用到了“外部数。据库”这个组件,这个组件里有关闭记录集的命令的。
回复

使用道具 举报

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

本版积分规则 致发广告者

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

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

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