Sie können es mit brutaler Gewalt tun:
select groupid,
(case when min(left(name, 10)) = max(left(name, 10)) then left(name, 10)
when min(left(name, 9)) = max(left(name, 9)) then left(name, 9)
when min(left(name, 8)) = max(left(name, 8)) then left(name, 8)
when min(left(name, 7)) = max(left(name, 7)) then left(name, 7)
when min(left(name, 6)) = max(left(name, 6)) then left(name, 6)
when min(left(name, 5)) = max(left(name, 5)) then left(name, 5)
when min(left(name, 4)) = max(left(name, 4)) then left(name, 4)
when min(left(name, 3)) = max(left(name, 3)) then left(name, 3)
when min(left(name, 2)) = max(left(name, 2)) then left(name, 2)
when min(left(name, 1)) = max(left(name, 1)) then left(name, 1)
end) as CommonPrefix
from t
group by groupid;
Wenn Sie nicht so viel tippen, können Sie auch tun:
select groupid,
max(case when min(left(name, n.n)) = max(left(name, n.n)) then left(name, n.n) end)
from t cross join
(select 1 as n union all selet 2 union all select 3 . . .
) n
group by groupid;
(Oder verwenden Sie einen where
Klausel die bekommen Informationen für eine Gruppe.) Für dieses Beispiel fügen Sie der Unterabfrage n
ganze Zahlen bis zur Länge hinzu, die Sie testen möchten.
+1 Das gut ist! –
Kennen Sie die genaue Anzahl der gemeinsamen Zeichen? – Chris
@crudolf, Wenn ich die genaue Anzahl der gemeinsamen Zeichen wüsste, würde ich sie einfach "substring" :) –