使用DISTINCT关键字或者GROUP BY子句可以去除重复记录,同时需要指定关联的字段。
当使用SQL进行两表关联时,可能会出现重复记录的情况,为了避免这种情况,可以使用以下方法:
1、使用DISTINCT关键字

在查询语句中使用DISTINCT关键字可以去除重复的记录,假设有两个表table1和table2,它们通过字段id进行关联,可以使用以下查询语句去除重复记录:
SELECT DISTINCT table1.*, table2.* FROM table1 JOIN table2 ON table1.id = table2.id;
2、使用子查询
可以使用子查询来避免重复记录,假设有两个表table1和table2,它们通过字段id进行关联,可以使用以下查询语句去除重复记录:
SELECT *
FROM (
SELECT * FROM table1
UNION ALL
SELECT * FROM table2
) AS temp_table;
3、使用GROUP BY子句
如果需要对关联后的记录进行分组,可以使用GROUP BY子句,假设有两个表table1和table2,它们通过字段id进行关联,可以使用以下查询语句去除重复记录:
SELECT table1.id, COUNT(*) as count FROM table1 JOIN table2 ON table1.id = table2.id GROUP BY table1.id;
4、使用ROW_NUMBER()窗口函数
可以使用ROW_NUMBER()窗口函数为每个分组分配一个唯一的行号,然后只选择行号大于1的记录,假设有两个表table1和table2,它们通过字段id进行关联,可以使用以下查询语句去除重复记录:

WITH temp_table AS (
SELECT *, ROW_NUMBER() OVER (PARTITION BY id ORDER BY id) AS row_num
FROM table1
JOIN table2 ON table1.id = table2.id
)
SELECT * FROM temp_table WHERE row_num > 1;
