求解下ORACLE对varchar2的between处理方式。望解答!

用字符类型查询时,结果如下:SQL>select*fromNOSECTwherestatus=1and'4615217182627'betweenbeginnoanden... 用字符类型查询时,结果如下:
SQL>select * from NOSECT where status=1 and '4615217182627' between beginno and endno;
RECID BEGINNO ENDNO STATUS
----- ------------- ------------- ------
4 40000000000 49999999999 1
8014 4615217182000 4615217182999 1
2 rows selected.
ZHHSC@CSHSC >exit

用数字类型查询时结果如下:
SQL>select * from nosect where 4615217182627 between beginno and endno;
RECID BEGINNO ENDNO STATUS
----- ------- ----- ------
0 rows selected.
求解,为什么会出现这样的结果?BEGINNO和ENDNO均为varchar2类型。Oracle对varchar2的between会怎么处理的。谢谢!
展开
 我来答
宁静致远_1971
2012-12-13
知道答主
回答量:21
采纳率:0%
帮助的人:5.7万
展开全部
那你转换一下就好了,select * from nosect where to_char(4615217182627) between beginno and endno;
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
威孚半导体技术
2024-08-19 广告
威孚(苏州)半导体技术有限公司是一家专注生产、研发、销售晶圆传输设备整机模块(EFEM/SORTER)及核心零部件的高科技半导体公司。公司核心团队均拥有多年半导体行业从业经验,其中技术团队成员博士、硕士学历占比80%以上,依托丰富的软件底层... 点击进入详情页
本回答由威孚半导体技术提供
星辰大海byj
2012-12-10 · TA获得超过1020个赞
知道小有建树答主
回答量:993
采纳率:100%
帮助的人:524万
展开全部
varchar2型比较时,会按字符从第一个开始比较,按字符ascii顺序比较
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
dl_会飞的青蛙
2012-12-10 · TA获得超过2456个赞
知道大有可为答主
回答量:3294
采纳率:0%
帮助的人:3356万
展开全部
字符的比较是通过asc码来比较的从第一个字符开始比较如果相等再比较下一个
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
僪语海iP
2012-12-10
知道答主
回答量:57
采纳率:0%
帮助的人:28.3万
展开全部
select * from NOSECT where status=1 and to_number(beginno) between 1 and 14615217182627
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
sven910
2012-12-10 · TA获得超过151个赞
知道小有建树答主
回答量:300
采纳率:0%
帮助的人:106万
展开全部
AscII码比较的
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式