Press n or j to go to the next uncovered block, b, p or k for the previous block.
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 | 1x 1x 1x 1x 1x 1x 1x 1x 3x 3x 3x 3x 3x 3x 3x 3x 3x 3x 1x | import {seq, optPrio, altPrio, Expression, ver, AlsoIn, regex as reg} from "../combi";
import {SQLCond} from ".";
import {IStatementRunnable} from "../statement_runnable";
import {Release} from "../../../version";
import {SQLJoinSource} from "./sql_join_source";
export class SQLJoin extends Expression {
public getRunnable(): IStatementRunnable {
const joinType = seq(optPrio(altPrio("INNER", "LEFT OUTER", "LEFT", "RIGHT OUTER", "RIGHT")), "JOIN");
const joinTag = optPrio(ver(Release.v795, reg(/^#[A-Z][A-Z0-9_]*$/i)));
const join = seq(joinType, joinTag, new SQLJoinSource(), "ON", SQLCond);
const crossJoin = ver(Release.v750, seq("CROSS JOIN", joinTag, new SQLJoinSource()), {also: AlsoIn.OpenABAP});
return altPrio(crossJoin, join);
}
} |