当数据库中存在多个 id 对应相同描述文本的情况时,可通过 group by 配合聚合函数(如 min)选取唯一代表 id,确保 combobox 显示无重复文本且每项仍携带有效主键。
在实际开发中,尤其是构建下拉选择控件(如 ComboBox)时,我们常需从数据库中提取“可读文本 + 唯一标识符”的键值对。但若原始表(如 engine)中存在多条记录具有相同 description 却不同 id(例如:id=101, description='Gasoline' 和 id=205, description='Gasoline'),直接使用 SELECT DISTINCT id, description 无法真正去重——因为 DISTINCT 作用于整行,只要 id 不同,两行即视为不同,结果中仍会出现重复文本。
✅ 正确做法是:以文本字段为分组依据,为每组选取一个有代表性的 ID。推荐使用 GROUP BY description 并配合聚合函数(如 MIN(id) 或 MAX(id)):
SELECT MIN(id) AS id, description AS text FROM engine WHERE description IS NOT NULL GROUP BY description;
该语句将:
⚠️ 注意事项:
性能;综上,GROUP BY + MIN(id) 是简洁、高效、兼容性强的去重方案,既满足 UI 层“文本不重复”的需求,又维持了数据层“ID 可追溯”的完整性。