SQL
虚拟表我有一个名为a的字符串,其中包含多个值,我有一张表b,其中包含多个值,我想使用sql语句来知道有哪些数据是a中有但是b中没有的
123456789CREATE TEMPORARY TABLE temp_a (value VARCHAR(255));INSERT INTO temp_a (value)VALUES ('value1'), ('value2'), ('value3');SELECT temp_a.valueFROM temp_aLEFT JOIN bON temp_a.value = b.valueWHERE b.value IS NULL;
这里使用了虚拟/临时表的概念,虚拟表不会实际创建一张表,只在当前连接可见,当关闭当前的数据库连接后, 会清除该缓存
连接时 ON 和 WHERE 的区别
在使用left jion时,on和where条件的区别如下:1、 on条件是在生成临时表时使用的条件,它不管on中的条件是否为真,都会返回左边表中的记录。2、where条件是在临时表生成好后,再对临时表进行 ...