DEFINE TEMP-TABLE foo NO-UNDO
FIELD pk AS INTEGER
FIELD t AS CHARACTER
FIELD fk AS INTEGER
// should be replaced with field b2 from bar
FIELD b AS LOGICAL
INDEX i t
.
DEFINE TEMP-TABLE bar NO-UNDO
FIELD pk2 AS INTEGER
FIELD t2 AS CHARACTER
FIELD b2 AS LOGICAL
INDEX i2 pk2
.
function createFoo returns logical ( pk as int, t as char, fk as int, b as logical ):
define buffer foo for foo.
create foo.
assign
foo.pk = pk
foo.t = t
foo.fk = fk
foo.b = b
.
end function.
function createBar returns logical ( pk as int, t as char, b as logical ):
define buffer bar for bar.
create bar.
assign
bar.pk2 = pk
bar.t2 = t
bar.b2 = b
.
end function.
createFoo( 1, 'so-one', 1, false ).
createFoo( 2, 'so-two', 1, false ).
createFoo( 3, 'so-three', 2, true ).
createBar( 1, 'so-four', false ).
createBar( 2, 'so-five', true ).
def var hq as handle no-undo.
def var cquery as char no-undo.
create query hq.
hq:add-buffer( buffer foo:handle ).
hq:add-buffer( buffer bar:handle ).
cquery = 'for each foo where foo.t begins "so"'
+ ', each bar outer-join where bar.pk2 = foo.fk and bar.b2 = false '
+ ' break by foo.fk'.
hq:query-prepare( cquery ).
hq:query-open().
do while hq:get-next():
message
( if hq:first-of( 1 ) = hq:last-of( 1 ) then 'unique' else 'ambiguous' )
foo.pk
foo.t
foo.fk
.
end.