Home > SQL Server Error Messages > Msg 537 - Invalid length parameter passed to the LEFT or SUBSTRING function. |
SQL Server Error Messages - Msg 537 - Invalid length parameter passed to the LEFT or SUBSTRING function. |
Server: Msg 537, Level 16, State 2, Line 1
Invalid length parameter passed to the LEFT or SUBSTRING
function.
The LEFT
string function returns the left part of a character string with the specified number of characters. Similarly, the SUBSTRING
string function returns part of a character string from a given starting location and with the specified number of characters. The syntax of each string function is as follows:
LEFT ( <character_expression>, <length> )
SUBSTRING ( <character_expression>, <start>, <length> )
In both functions, the <character_expression>
is an expression of character or binary data while the <length>
is a positive integer that specifies how many characters or bytes of the <character_expression>
will be returned. In the case of the SUBSTRING
string function, the <start>
parameter is an integer that specified where the substring starts.
If the value passed to the <length>
parameter is negative, this error message will be encountered. Here’s a script that uses the LEFT
string function that doesn’t produce this error:
DECLARE @FullName VARCHAR(50)
DECLARE @Length INT
SET @FullName = 'Mickey Mouse'
SET @Length = CHARINDEX(' ', @FullName)
SELECT LEFT(@FullName, @Length - 1) AS [FirstName]
And this is the output of this script.
| FirstName |
|-----------|
| Mickey |
Using this script and changing the value of the string being parsed, in this case the Full Name
, and assigning it a value that doesn't have a space in it, then this error will be generated.
DECLARE @FullName VARCHAR(50)
DECLARE @Length INT
SET @FullName = 'Goofy'
SET @Length = CHARINDEX(' ', @FullName)
SELECT LEFT(@FullName, @Length - 1) AS [FirstName]
GO
Msg 537, Level 16, State 2, Line 12
Invalid length parameter passed to the LEFT or SUBSTRING function.
Since there is no space in the value of the @FullName
, the CHARINDEX
string function will return a value of 0 since it was not able to find the search string (in this case, the space) from the string expression passed. Subtracting 1 from it yields a value of -1, which is not allowed as the length in the LEFT
function.
Modifying the script to use the SUBSTRING string function instead of the LEFT string function will also generate the same error message:
DECLARE @FullName VARCHAR(50)
DECLARE @Length INT
SET @FullName = 'Pluto'
SET @Length = CHARINDEX(' ', @FullName)
SELECT SUBSTRING(@FullName, 1, @Length - 1) AS [FirstName]
GO
Msg 537, Level 16, State 2, Line 12
Invalid length parameter passed to the LEFT or SUBSTRING function.
This error message can easily be avoided by making sure that the integer value passed as the length to either the LEFT
substring function or SUBSTRING
string function is not negative. One way of checking it within the LEFT
or SUBSTRING
function is with the use of the CASE
function. The CASE
function evaluates a list of conditions and returns one of multiple possible result expressions. In this case, all that is needed to be evaluated is the value of the length and make sure that if ever it is negative, a different value will be passed to it. In this particular case, if the space (or full name separator) is not found, the length of the original string is returned.
Here's how the scripts will now look like with the incorporation of the CASE
function within either the LEFT
or SUBSTRING
function and thus not generating the error:
SELECT LEFT([Name],
CASE WHEN CHARINDEX(' ', [Name]) - 1 < 0
THEN LEN([Name])
ELSE CHARINDEX(' ', [Name]) - 1 END) AS [FirstNameUsingLeft],
SUBSTRING([Name], 1,
CASE WHEN CHARINDEX(' ', [Name]) - 1 < 0
THEN LEN([Name])
ELSE CHARINDEX(' ', [Name]) - 1 END) AS [FirstNameUsingSubstring]
FROM (VALUES ('Mickey Mouse'),
('Minnie Mouse'),
('Donald Duck'),
('Daisy Duck'),
('Goofy'),
('Pluto'))
AS [Characters] ( [Name] )
GO
| FirstNameUsingLeft | FirstNameUsingSubstring | |--------------------|-------------------------| | Mickey | Mickey | | Minnie | Minnie | | Donald | Donald | | Daisy | Daisy | | Goofy | Goofy | | Pluto | Pluto |
Figure 1: Error Message 537 - Solution #1 - Using CASE
Statements
The indentation of the CASE
function together with the WHEN
, THEN
and ELSE
is only done for readability and is not required.