JOIN

New in version 2.00.10.

语法

SELECT column_name(s)
FROM table1
JOIN table2
[ON table1.matchingCol1=table2.MatchingCol2]

参数

table1/table2 是待连接的表。

matchingCol1/matchingCol2 表示连接列。

详情

当不指定 ON 连接条件时,执行 CROSS JOIN 连接,返回两个表的笛卡尔积的结果集。

当指定 ON 连接条件时,执行 INNER JOIN 连接,返回连接表中满足限制条件的行的结果集。

请注意:

暂不支持非等值连接,例如:t1 JOIN t2 ON t1.id <op> t2.id,其中 <op> 为:>, <,>=, <=, <> 。

如果有多个连接列,必须使用 AND 连接。

不能和 UPDATE 关键字一起使用。

在版本 2.00.10 之前,执行 select * from table1 join table2 等同于简单地将两张表进行合并,即 join(a,b)。

例子

t1 = table(1 2 3 3 as id, 7.8 4.6 5.1 0.1 as value, 4 3 2 1 as x)
t2 = table(5 3 1 2 as idv,  300 500 800 200 as qty, 4 6 4 5 as xv);
SELECT * FROM t1 JOIN t2 WHERE x>3
//等价于 SELECT * FROM t1 CROSS JOIN t2 WHERE x>3 或 SELECT * FROM cj(t1,t2) WHERE x>3;

id

value

x

idv

qty

xv

1

7.8

4

5

300

4

1

7.8

4

3

500

6

1

7.8

4

1

800

4

1

7.8

4

2

200

5

SELECT * FROM t1 JOIN t2 ON t1.id=t2.idv ;
//等价于 SELECT * FROM t1 INNER JOIN t2 ON t1.id=t2.idv

id

value

x

qty

xv

1

7.8

4

800

4

2

4.6

3

200

5

3

5.1

2

500

6

3

0.1

1

500

6