sql – 为什么选择多个表而不加入

在连接表时,传统上可以使用sql89的加入方式
SELECT * FROM t1,t2 WHERE t1.id = t2.t1_id;

但是从sql92标准开始,我们现在可以使用JOIN语法进行连接

SELECT * FROM t1 JOIN t2 on t1.id=t2.t1_id;

是否有人会在没有加入的情况下从多个表中进行SELECT?
现在,我知道人们使用UNION连接数据,但这不是我所说的.

我们之所以在FROM子句中使用逗号添加表格是为了向后兼容吗?或者是否存在任何使用旧语法的现实场景只能通过连接进行?

解决方法

如果由于某种原因需要完整的笛卡尔产品,它可能会有用.例如,如果您有汽车模型表和汽车颜色表,并且想要枚举所有选项,则不需要连接. 话虽如此,我认为这是一个边缘案例.

相关文章

SELECT a.*,b.dp_name,c.pa_name,fm_name=(CASE WHEN a.fm_n...
if not exists(select name from syscolumns where name=&am...
select a.*,pano=a.pa_no,b.pa_name,f.dp_name,e.fw_state_n...
要在 SQL Server 2019 中设置定时自动重启,可以使用 Window...
您收到的错误消息表明数据库 'EastRiver' 的...
首先我需要查询出需要使用SQL Server Profiler跟踪的数据库标...