SQL Server няма много добри функции за манипулиране на низове. Това е по-лесно с подзаявки:
select firstname,
stuff(reverse(stuff(reverse(legalname), 1, len(lastname) + 1, '')),
1, len(firstname) + 1, '')
from (select legalname,
left(legalname, charindex(' ', legalname) - 1) as firstname,
right(legalname, charindex(' ', reverse(legalname)) - 1) as lastname
. . .
) c
Въпреки това бих бил много внимателен, защото не всички хора имат три части имена. А други имат наставки (JR, SR) и други усложнения.