现在有表1包含字段id,age,money;表2中id,name,表1中id无重复,表二中,id很多重复,因为一个id对应多个name,如:id=1,对应有name有:三丰,张三丰,id=2对应name有:小明,刘小明
现在我想要结果集包含表1的id,money,age,并且关联表2获取name,但是我只要一个name名,而且想要最长的那个名,如何限定条件呢,我之前写的是,max(name),max应该是根据首字母的顺序排的大小,所以id=2选出来是小明而不是刘小明,所以请问如何解决这个问题呢
sql中一对多字段如何选取名字最长的字段
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
3条回答 默认 最新
关注 试试我写的这个,但是也有个问题,如果还有个刘大明,那么长度跟刘小明一样,你要怎么取?
如有帮助,请采纳。select t1.id, t1.money, t1.age, t2.name from 表1 t1 left join ( select id,name from( select id,name, ROW_NUMBER() OVER(partition by id order by length(name) desc) col from 表2 ) b where col=1 ) t2 on t1.id=t2.id
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥20 西门子S7-Graph,S7-300,梯形图
- ¥50 用易语言http 访问不了网页
- ¥50 safari浏览器fetch提交数据后数据丢失问题
- ¥15 matlab不知道怎么改,求解答!!
- ¥15 永磁直线电机的电流环pi调不出来
- ¥15 用stata实现聚类的代码
- ¥15 请问paddlehub能支持移动端开发吗?在Android studio上该如何部署?
- ¥20 docker里部署springboot项目,访问不到扬声器
- ¥15 netty整合springboot之后自动重连失效
- ¥15 悬赏!微信开发者工具报错,求帮改