Lors de la migration de requêtes de MySQL vers SQL Server, il est souvent nécessaire de trouver des équivalents SQL Server pour les fonctions MySQL couramment utilisées.
La fonction SUBSTRING_INDEX() de MySQL récupère une sous-chaîne d'une chaîne donnée en fonction de l'occurrence d'un délimiteur spécifié. Sa syntaxe est :
SUBSTRING_INDEX(str, delim, count)
Par exemple :
SELECT SUBSTRING_INDEX('www.somewebsite.com','.',2);
Cela renverrait 'www.somewebsite'.
Une option viable dans T-SQL pour répliquer la fonctionnalité de SUBSTRING_INDEX() est une combinaison de XQuery et d'une fonction scalaire :
CREATE FUNCTION dbo.SUBSTRING_INDEX ( @str NVARCHAR(4000), @delim NVARCHAR(1), @count INT ) RETURNS NVARCHAR(4000) WITH SCHEMABINDING BEGIN DECLARE @XmlSourceString XML; SET @XmlSourceString = (SELECT N'<root><row>' + REPLACE( (SELECT @str AS '*' FOR XML PATH('')) , @delim, N'</row><row>' ) + N'</row></root>'); RETURN STUFF ( (( SELECT @delim + x.XmlCol.value(N'(text())[1]', N'NVARCHAR(4000)') AS '*' FROM @XmlSourceString.nodes(N'(root/row)[position() <= sql:variable("@count")]') x(XmlCol) FOR XML PATH(N''), TYPE ).value(N'.', N'NVARCHAR(4000)')), 1, 1, N'' ); END GO
Exemple d'utilisation :
SELECT dbo.SUBSTRING_INDEX(N'www.somewebsite.com', N'.', 2) AS Result;
Sortie :
Result --------------- www.somewebsite
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!