使用方式
select distinct column
from table_name
使用order by时遇到的错误
使用order by排序时,sql语句为
SELECT DISTINCT
from_bank_code
FROM
sys_cross_bank_setting
WHERE
type = 1
ORDER BY
sort
出现报错
3065 - Expression 1 of ORDER BY clause is not in SELECT list, references column 'onepay.sys_cross_bank_setting.sort' which is not in SELECT list; this is incompatible with DISTINCT
- 是因为MySQL建立了内部临时表进行查询,如果查询中使用了内部临时表他只会包含去重的字段而不包含其它字段,所以导致了报错。类似的情况还有
GROUP BY
、UNION
等关键字的使用,这种情况只包含没有对这个字段创建索引的情况。 - 如果进行去重或分组的字段有建立索引,MySQL会利用索引来完成分组或去重。
修改后为
SELECT DISTINCT
from_bank_code, sort
FROM
sys_cross_bank_setting
WHERE
type = 1
ORDER BY
sort
加上需要排序的字段就可以了
扩展
如何查看MySQL是否建立临时表来完成查询?
使用EXPLAIN关键字进行查询,如果出现Extra字段的值中出现了Using temporary
则说明使用了临时表