SQL 使用 SUBSTRING 和 LEN 的问题

SQL Issue using SUBSTRING and LEN

SELECT [Code], [Due Date Calculation],

--original string that is causing the error
--SUBSTRING([Due Date Calculation], 1, LEN([Due Date Calculation]) - 1) as OG,

--here are the tests that run fine by themselves
LEN([Due Date Calculation]) - 1 as Test1,
SUBSTRING([Due Date Calculation], 1, 2) AS Test2, 
SUBSTRING([Due Date Calculation], 1, LEN([Due Date Calculation])) AS Test3 

FROM [TEST]

这是我收到的错误:

Msg 537, Level 16, State 2, Line 1 Invalid length parameter passed to the LEFT or SUBSTRING function.

我知道这与 SQL 呈现数据的方式有关。当我使用 SQL 查询数据时,数据显示一个小的颠倒 'L',但它只是在前端显示一个 'D'。我没有足够好的声誉来包含这些图像。典型代码的示例有 30D60D120D365D

我需要去掉尾随的 D 并显示剩下的内容。

感谢您的帮助。

以下是 SQL 查询的结果: [https://drive.google.com/file/d/0B1cL-bzbZ4IzU2ctYlRNZnJhZjg/view?usp=sharing][1]

如果我正确理解你的问题,你正在寻找这个

Select SUBSTRING([Due Date Calculation],0,CHARINDEX('D',[Due Date Calculation])) 
As [Due Date Calculation]  FROM Test

SQLFIDDLE

这是我的样本

declare @tbl table
(
    c1 nvarchar(9)
)
insert into @tbl values ('30D')
insert into @tbl values ('120D')
insert into @tbl values ('365D')

select  IIF(RIGHT(c1, 1) = 'D', LEFT(C1, LEN(C1)-1), C1)
from    @tbl

结果
30
120
365

如果要截掉最后一个字符,就这样吧。

DECLARE @String VARCHAR(100) = '123D'

SELECT SUBSTRING(@String,0,LEN(@String))

或者如果你的末尾有多个字符,那么试试这个,它会抓取直到数字停止。

DECLARE @String VARCHAR(100) = '123D'

SELECT SUBSTRING(@String,0,PATINDEX('%[^0-9]%',@String))

两者的结果相同:

123