-
Notifications
You must be signed in to change notification settings - Fork 664
Join
Andrey Gershun edited this page May 25, 2015
·
9 revisions
Supported join types:
- [INNER] JOIN
- LEFT [OUTER] JOIN
- RIGHT [OUTER] JOIN
- [FULL] OUTER JOIN
- ANTI JOIN
- SEMI JOIN
- CROSS JOIN
- NATURAL JOIN
alasql('SELECT * FROM Cities JOIN Countries');
alasql('SELECT city.*, country.* FROM city \
JOIN country USING countryid');
alasql('SELECT * FROM Cities JOIN Countries USING Country');
alasql('SELECT city.*, country.* FROM city \
JOIN country ON city.countryid = country.countryid');
alasql('SELECT * FROM Cities JOIN Countries ON Citites.Country = Countries.Country');
Actually AlaSQL converts internally to the same execution plan, like in this example:
JOIN USING works fine in this example
var data = { COLORS: [[1,"red"],[2,"yellow"],[3,"orange"]],
"FRUITS":[[1,"apple"],[2,"banana"],[3,"orange"]]};
data.NEW_FRUITS = alasql('SELECT MATRIX COLORS.[0], COLORS.[1], \
FRUITS.[1] AS [2] FROM ? AS COLORS JOIN ? AS FRUITS USING [0]',
[data.COLORS, data.FRUITS]);
With using JOIN ON in this example:
var data = { COLORS: [[1,"red"],[2,"yellow"],[3,"orange"]],
"FRUITS":[[1,"apple"],[2,"banana"],[3,"orange"]]};
data.NEW_FRUITS = alasql('SELECT MATRIX COLORS.[0], COLORS.[1], FRUITS.[1] AS [2] \
FROM ? AS COLORS JOIN ? AS FRUITS ON COLORS.[0] = FRUITS.[0]',
[data.COLORS, data.FRUITS]);
© 2014-2024, Andrey Gershun & Mathias Rangel Wulff
Please help improve the documentation by opening a PR on the wiki repo