Bootstrap

mysql使用distinct关键字

使用方式

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 BYUNION等关键字的使用,这种情况只包含没有对这个字段创建索引的情况
  • 如果进行去重或分组的字段有建立索引,MySQL会利用索引来完成分组或去重。

修改后为

SELECT DISTINCT
	from_bank_code, sort
FROM
	sys_cross_bank_setting 
WHERE
	type = 1 
ORDER BY
	sort
加上需要排序的字段就可以了

扩展

如何查看MySQL是否建立临时表来完成查询?

使用EXPLAIN关键字进行查询,如果出现Extra字段的值中出现了Using temporary则说明使用了临时表

;