mysql使用distinct关键字

文章讲述了在MySQL中使用DISTINCT和ORDERBY时遇到的错误,原因是内部临时表只包含去重字段。解决方法是添加需要排序的字段到SELECT列表。此外,提供了解决方案——通过EXPLAIN查看是否使用临时表。
摘要由CSDN通过智能技术生成

使用方式

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则说明使用了临时表

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值