select /* + mapjoin(a) */
A.artist_id,A.ds,datediff(day,max(tianchi_songs.publish_time),A.ds) as timediff
from (select artist_id,play,ds
from predicttable2
where action_type=1)A JOIN tianchi_songs
on A.artist_id=tianchi_songs.artist_id and tianchi_songs.publish_time<= A.ds
运行类似这样的代码,都会报错,不是很懂啊,看一天了,能不能请教下mapjoin应该怎么写? on中不等值连接应该怎么写?
FAILED: ODPS-0130071:Semantic analysis exception - E
xpression not in GROUP BY key : line 2:0 'ds'
还有一点不明白 select语句中 from
tianchi_user_action, tianchi_songs
这样居然也报错odps sql 不支持的么?
1.max聚合函数,需把select中其他不聚合的字段,放到group by里 2. datediff的字段,需转换为datetime类型
-------------------------
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。