标题:求解字符对比的问题,同样的数据不同的结果(数据已提供)
只看楼主
hjlali
Rank: 1
等 级:新手上路
帖 子:48
专家分:0
注 册:2008-12-23
结帖率:100%
已结贴  问题点数:10 回复次数:19 
求解字符对比的问题,同样的数据不同的结果(数据已提供)
两个表f1和y1.都包含了lxfs字段,字段长度都是50
? SET('ansi')  && off
? SET('exact') && off
f1.lxfs=1767163
y1.lxfs=176716

奇怪的现象来了
? '1767163'='176716'  &&结果是.T.
? f1.lxfs=y1.lxfs    &&结果是.F.,这是为啥?



字符对比.rar (293 Bytes)


[此贴子已经被作者于2021-8-22 11:35编辑过]

搜索更多相关主题的帖子: 字符 不同 对比 数据 结果 
2021-08-22 11:33
sdta
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:江苏省连云港市
等 级:版主
威 望:323
帖 子:9621
专家分:26174
注 册:2012-2-5
得分:3 
静下心来多看看帮助文件是怎么说的

坚守VFP最后的阵地
2021-08-22 11:38
hjlali
Rank: 1
等 级:新手上路
帖 子:48
专家分:0
注 册:2008-12-23
得分:0 
以下是引用sdta在2021-8-22 11:38:52的发言:

静下心来多看看帮助文件是怎么说的

我这几天都在很认真的学习,实在搞不懂了才来论坛提问,求指点指点。

喜欢VFP,就要学懂弄通!
2021-08-22 12:16
sdta
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:江苏省连云港市
等 级:版主
威 望:323
帖 子:9621
专家分:26174
注 册:2012-2-5
得分:0 
多看多练是关键

坚守VFP最后的阵地
2021-08-22 12:36
吹水佬
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:432
帖 子:10064
专家分:41463
注 册:2014-5-20
得分:3 
回复 楼主 hjlali
没考虑字符串长度属性了。
字符串比较有两个主要属性:对应的字符比对和字符串长度比对。
字符串比较结果:< 或 = 或 >
2021-08-22 12:48
hjlali
Rank: 1
等 级:新手上路
帖 子:48
专家分:0
注 册:2008-12-23
得分:0 
以下是引用吹水佬在2021-8-22 12:48:06的发言:

没考虑字符串长度属性了。
字符串比较有两个主要属性:对应的字符比对和字符串长度比对。
字符串比较结果:< 或 = 或 >

我前面说过了,两个表中lxfs字段的长度和属性都是一样的,你们自己可以看看表结构。
为什么结果还是.F.呢?

喜欢VFP,就要学懂弄通!
2021-08-22 13:01
hjlali
Rank: 1
等 级:新手上路
帖 子:48
专家分:0
注 册:2008-12-23
得分:0 
以下是引用sdta在2021-8-22 12:36:45的发言:

多看多练是关键

大师说的对,我也在多看多练,都连续练习两天了,在电脑面前一坐就是七八个小时,是我愚钝,或者是哪里疏忽了。
你能把原因说明白点吗,谢谢了!!

下面几篇文章都学了


[此贴子已经被作者于2021-8-22 13:10编辑过]


喜欢VFP,就要学懂弄通!
2021-08-22 13:03
pjtyzyq
Rank: 4
等 级:业余侠客
威 望:6
帖 子:230
专家分:240
注 册:2016-2-14
得分:3 
? LEN(y1.lxfs)是多少?
你的比较相当于:
f1.lxfs="1767163"
y1.lxfs="176716 "
所以结果不同
2021-08-22 13:31
hjlali
Rank: 1
等 级:新手上路
帖 子:48
专家分:0
注 册:2008-12-23
得分:0 
以下是引用pjtyzyq在2021-8-22 13:31:11的发言:

? LEN(y1.lxfs)是多少?
你的比较相当于:
f1.lxfs="1767163"
y1.lxfs="176716 "
所以结果不同

? LEN(y1.lxfs)  结果是50
? LEN(f1.lxfs)   结果也是50
他们的长度是一样的。
按照VFP的规则,当为set exact OFF(默认值 )状态时,只要右端字符串与左端字符串的左子串相等,则就认为是真,否则是假。
如:? ′ABC′=′AB′ &&显示  .T.

也就是说,
? f1.lxfs=y1.lxfs   结果应该为.T.,但为什么实际运行结果是.F.呢?我真没弄明白!!

喜欢VFP,就要学懂弄通!
2021-08-22 13:50
pjtyzyq
Rank: 4
等 级:业余侠客
威 望:6
帖 子:230
专家分:240
注 册:2016-2-14
得分:0 
你验证一下?"1767163"="176716 "和?"1767163"="176716"及?"176716"="1767163"

[此贴子已经被作者于2021-8-22 14:03编辑过]

2021-08-22 14:00



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-506610-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.222393 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved