From 99d148506744c4d1cb1e99afeed426d37ca186a6 Mon Sep 17 00:00:00 2001 From: Jonas Staudenmeir Date: Fri, 17 Nov 2023 18:14:10 +0100 Subject: [PATCH] Fix length limit of path columns on SQL Server --- src/Query/Grammars/SqlServerGrammar.php | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/src/Query/Grammars/SqlServerGrammar.php b/src/Query/Grammars/SqlServerGrammar.php index 32dda88..4895ce5 100644 --- a/src/Query/Grammars/SqlServerGrammar.php +++ b/src/Query/Grammars/SqlServerGrammar.php @@ -19,7 +19,7 @@ class SqlServerGrammar extends Base implements ExpressionGrammar */ public function compileInitialPath($column, $alias) { - return 'cast('.$this->wrap($column).' as varchar) as '.$this->wrap($alias); + return 'cast('.$this->wrap($column).' as varchar(max)) as '.$this->wrap($alias); } /** @@ -36,10 +36,10 @@ public function compileRecursivePath($column, $alias, bool $reverse = false) $wrappedAlias = $this->wrap($alias); if ($reverse) { - return "cast(cast($wrappedColumn as varchar) + ? + $wrappedAlias as varchar) as $wrappedAlias"; + return "cast(cast($wrappedColumn as varchar(max)) + ? + $wrappedAlias as varchar(max)) as $wrappedAlias"; } - return "cast($wrappedAlias + ? + cast($wrappedColumn as varchar) as varchar) as $wrappedAlias"; + return "cast($wrappedAlias + ? + cast($wrappedColumn as varchar(max)) as varchar(max)) as $wrappedAlias"; } /** @@ -94,7 +94,7 @@ public function compileCycleDetection(string $localKey, string $path): string $localKey = $this->wrap($localKey); $path = $this->wrap($path); - $castLocalKey = "cast($localKey as varchar)"; + $castLocalKey = "cast($localKey as varchar(max))"; return "charindex($castLocalKey + ?, $path) > 0 or charindex(? + $castLocalKey + ?, $path) > 0"; }