开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

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


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

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

查看: 147|回复: 10
收起左侧

[易语言] 保存到XML 失败的问题

[复制链接]
结帖率:97% (34/35)
发表于 昨天 10:09 | 显示全部楼层 |阅读模式   广东省深圳市
50精币
UPS记录集.1打开 (“select * from test where id='1'”, #SQL语句, )
sql = 记录集1.保存到XML (取运行目录 () + “\temp\sqlSwap.xml”)UPS记录集1.关闭 ()

第一次保存成功,但第二次再运行代码保存就会失败。
尝试过删除文件也能正常删除成功(测试文件是否被占用,能删除所以没被占用),再保存还是失败。
用了随机数文件名,每次都会成功,这是啥原理咋解决






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

签到天数: 6 天

发表于 昨天 10:30 | 显示全部楼层   河南省驻马店市
即使显示文件未被占用,系统可能在储存的时候是占用的。

试试吧资源释放掉。


UPS记录集.1打开 (“select * from test where id='1'”, #SQL语句, )
sql = 记录集1.保存到XML (取运行目录 () + “\temp\sqlSwap.xml”)
UPS记录集1.关闭 ()
处理事件 ()
延迟 (500)  
回复

使用道具 举报

结帖率:97% (34/35)

签到天数: 2 天

 楼主| 发表于 昨天 10:42 | 显示全部楼层   广东省深圳市
laihobglei 发表于 2025-7-5 10:30
即使显示文件未被占用,系统可能在储存的时候是占用的。

试试吧资源释放掉。

还是不行
回复

使用道具 举报

签到天数: 6 天

发表于 昨天 10:49 | 显示全部楼层   河南省驻马店市
.版本 2
.支持库 eDB

.如果真 (文件是否存在 (取运行目录 () + “\temp\sqlSwap.xml”))
    移动文件 (取运行目录 () + “\temp\sqlSwap.xml”, 取运行目录 () + “\temp\sqlSwap_old.xml”)
.如果真结束
试试使用内存流中转

UPS记录集1.打开 (“select * from test where id='1'”, #SQL语句, )
sql = 记录集1.保存到XML (取运行目录 () + "\temp\sqlSwap.xml")

UPS记录集1.关闭 ()
回复

使用道具 举报

结帖率:97% (34/35)

签到天数: 2 天

 楼主| 发表于 昨天 10:54 | 显示全部楼层   广东省深圳市
laihobglei 发表于 2025-7-5 10:49
.版本 2
.支持库 eDB

也不行,第二次再保存XML还是会失败

sql = 连接.UPS记录集.保存到XML (取运行目录 () + “\temp\sqlSwap.xml”)
连接.UPS记录集.关闭 ()

.如果真 (文件是否存在 (取运行目录 () + “\temp\sqlSwap.xml”))
    移动文件 (取运行目录 () + “\temp\sqlSwap.xml”, 取运行目录 () + “\temp\sqlSwap_old.xml”)
.如果真结束

调试输出 (sql, “保存持久文件”)
回复

使用道具 举报

结帖率:97% (34/35)

签到天数: 2 天

 楼主| 发表于 昨天 10:55 | 显示全部楼层   广东省深圳市
laihobglei 发表于 2025-7-5 10:49
.版本 2
.支持库 eDB

换个文件名就会成功,但是这样不安全,而且也会增加不必要的流程
回复

使用道具 举报

签到天数: 6 天

发表于 昨天 11:02 | 显示全部楼层   河南省驻马店市
试试解锁下文件。实在不行我也没办法了。

  
窗口程序集名保 留  保 留备 注
窗口程序集_启动窗口   
子程序名返回值类型公开备 注
__启动窗口_创建完毕  
UPS记录集.1打开 (“select * from test where id='1'”, #SQL语句, )
强制解锁文件 ()
sql = 记录集1.保存到XML (取运行目录 ()“\temp\sqlSwap.xml”)
UPS记录集1.关闭 ()
子程序名返回值类型公开备 注
强制解锁文件  
变量名类 型静态数组备 注
句柄整数型 
句柄 = 打开文件 (取运行目录 ()“\temp\sqlSwap.xml”, #读写, )
如果真 (句柄 ≠ 0)
解除文件锁 (句柄)


  
DLL命令名返回值类型公开备 注
解除文件锁逻辑型 
DLL库文件名:
kernel32.dll
在DLL库中对应命令名:
CloseHandle
参数名类 型传址数组备 注
文件句柄整数型


回复

使用道具 举报

结帖率:97% (34/35)

签到天数: 2 天

 楼主| 发表于 昨天 12:12 | 显示全部楼层   广东省深圳市
保存到XML 失败的时候,用写到文件能把数据写进去。。。。这是记录集组件BUG问题吗?
回复

使用道具 举报

结帖率:0% (0/1)

签到天数: 5 天

发表于 昨天 16:33 | 显示全部楼层   福建省福州市
能删除成功,第二次不能保存?无代码没办法排查,太久没用,不知道只读文件会不会影响写入。看一下文件是否是只读
回复

使用道具 举报

结帖率:97% (34/35)

签到天数: 2 天

 楼主| 发表于 昨天 18:59 | 显示全部楼层   广东省深圳市
laihobglei 发表于 2025-7-5 11:02
试试解锁下文件。实在不行我也没办法了。

  
[/quote]
还是不行,谢谢大佬,应该是组件BUG的问题。
第1次文件名如果是A,第二次必须是非A,否则就会出错保存XML失败,只能通过下面随机文件名哎:
[e=0].版本 2
sql语句 = 记录集.打开 (“select * from test where id='1'”, #SQL语句, )
记录集.到首记录 ()
' //记录集.保存到XML 有BUG,同一个文件名不能保存多次
置随机数种子 ()
随机数 = 取随机数 (10000, 99999)
循环判断首 ()
xml文件目录 = 取运行目录 ()“\temp\”
xml文件名 = “sqlSwap”生成前置时间戳 ()到文本 (随机数)“.xml”
保存状态 = 记录集.保存到XML (xml文件目录 + xml文件名)
如果真 (保存状态 = )
随机数 = 取随机数 (10000, 99999)

循环判断尾 (保存状态 = )
UPS记录集.关闭 ()


i支持库列表   支持库注释   
eDB数据库操作支持库


回复

使用道具 举报

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

本版积分规则 致发广告者

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

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

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