SELECT ROW(1,2,3)=ROW(1,2,3); ROW(1,2,3)=ROW(1,2,3) 1 SELECT ROW(2,2,3)=ROW(1+1,2,3); ROW(2,2,3)=ROW(1+1,2,3) 1 SELECT ROW(1,2,3)=ROW(1+1,2,3); ROW(1,2,3)=ROW(1+1,2,3) 0 SELECT ROW(1,2,3)ROW(1+1,2,3); ROW(1,2,3)>ROW(1+1,2,3) 0 SELECT ROW(1,2,3)<=ROW(1+1,2,3); ROW(1,2,3)<=ROW(1+1,2,3) 1 SELECT ROW(1,2,3)>=ROW(1+1,2,3); ROW(1,2,3)>=ROW(1+1,2,3) 0 SELECT ROW(1,2,3)<>ROW(1+1,2,3); ROW(1,2,3)<>ROW(1+1,2,3) 1 SELECT ROW(NULL,2,3)=ROW(NULL,2,3); ROW(NULL,2,3)=ROW(NULL,2,3) NULL SELECT ROW(NULL,2,3)<=>ROW(NULL,2,3); ROW(NULL,2,3)<=>ROW(NULL,2,3) 1 SELECT ROW(1,2,ROW(3,4,5))=ROW(1,2,ROW(3,4,5)); ROW(1,2,ROW(3,4,5))=ROW(1,2,ROW(3,4,5)) 1 SELECT ROW('test',2,3.33)=ROW('test',2,3.33); ROW('test',2,3.33)=ROW('test',2,3.33) 1 SELECT ROW('test',2,3.33)=ROW('test',2,3.33,4); Cardinality error (more/less than 3 columns) drop table if exists t1; create table t1 ( a int, b int, c int); insert into t1 values (1,2,3), (2,3,1), (3,2,1); select * from t1 where ROW(1,2,3)=ROW(a,b,c); a b c 1 2 3 select * from t1 where ROW(0,2,3)=ROW(a,b,c); a b c select * from t1 where ROW(1,2,3)