当前位置: 代码迷 >> Sql Server >> 一个简单的sql。想学习一下解决方案
  详细解决方案

一个简单的sql。想学习一下解决方案

热度:151   发布时间:2016-04-27 14:09:15.0
一个简单的sql。想学习一下
表名为A 字段 id,username,score,note
将A表里面的数据复制到B表里面,如果username相同 则取最大的score那一条数据,B表与A表结构相同。


------解决方案--------------------
SQL code
select * from A t where not exists(select 1 from A where username=t.username and score>t.score)
------解决方案--------------------
SQL code
insert into B表select t.id,t.username,t.score,t.notefrom(select id,username,score,note,row_number over(partition by username order by score desc) rnfrom A表) twhere t.rn=1
  相关解决方案