这是我的'联系人'表.
| Names | Gender |
| Mike | Male |
| Steve | Male |
| Kelly | Female |
| Jane | Female |
| Natasha | Female |
| Mathew | Male |
| Jack | Male |
Run Code Online (Sandbox Code Playgroud)
我想要这样的结果:
| Male | Female |
| Mike | Kelly |
| Steve | Jane |
| Mathew | Natasha |
| Jack | |
Run Code Online (Sandbox Code Playgroud)
请给我解决方案在SQL Sever中实现此结果...任何建议表示赞赏!
with Male as
(
select Names,
row_number() over(order by Names) as rn
from YourTable
where Gender = 'Male'
),
Female as
(
select Names,
row_number() over(order by Names) as rn
from YourTable
where Gender = 'Female'
)
select Male.Names as Male,
Female.Names as Female
from Male
full outer join Female
on Male.rn = Female.rn
Run Code Online (Sandbox Code Playgroud)
不是您想要的确切结果,但是如果没有其他列可以获得,那么就好了.
Male Female
------- -------
Jack Jane
Mathew Kelly
Mike Natasha
Steve NULL
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
829 次 |
| 最近记录: |