选择一条记录: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条数据。
各有好处。