single 與 up to 1 rows的區別

[@more@]
选择一条记录:single 、 up to 1 rows
使用single : 在where语句中如果使用了全部的key字段可以使用single
格式: SELECT single Field_Name_List
FROM Table_Name
WHERE Condition_List
使用up to 1 rows : 在where语句中如果使用了部分或没有使用key字段,则只能使用up to 1 rows
格式 : SELECT Field_Name_List
FROM Table_Name
up to 1 rows
WHERE Condition_List
ENDSELECT
例题 : 表kssk,其中MANDT、OBJEK、MAFID、KLART、CLINT、ADZHL为key字段。
使用single : SELECT single CLINT
INTO KSSK-CLINT
FROM KSSK
WHERE OBJEK EQ INOD-CUOBJ
AND MAFID EQ C_O_SIGN
AND KLART EQ C_KLART
使用up to 1 rows : SELECT CLINT
INTO KSSK-CLINT
FROM KSSK
up to 1 rows
WHERE OBJEK EQ INOD-CUOBJ
AND MAFID EQ C_O_SIGN
AND KLART EQ C_KLART
ENDSELECT
在使用single时是错误的,而使用up to 1 rows是正确的。
因为single,在where子句中要使用所有key字段的作为条件才能使用single。
而up to 1 rows 则使用了部分或没有使用key字段都可以使用。
single 取第一个符合条件的数据,不需要继续再查找下去。
up to 1 rows 先查找所有数据,再取一条符合条件的数据。
up to n rows 可以取n条数据。
各有好处。

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/9437124/viewspace-997334/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/9437124/viewspace-997334/

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值