sql - SQL 无法将 int 转换为 varchar(15) 值并抛出:将 varchar 值“LBS”转换为数据类型 int 时转换失败
问题描述
我正在开发一个 SQL 项目,该项目从许多表中提取数据以在电子邮件正文中列出它们。在我的电子邮件正文中,我正在提取引发异常的 int 值,因为正文最终需要是 nvarchar(max)。不同类型的转换还没有为我工作。
这是在 Microsoft SQL Server Management Studio 上运行的 SQL。我尝试过不转换 int,以及我在其他地方看到的一些不同的转换方法。
在示例中,wtpc.Reg_No是一个 varchar,wtpc.Shipment_Net_Weight是一个 int。
'Body' =
...
+ 'Net: ' +
CASE
WHEN wtpc.Reg_No IS NOT NULL THEN wtpc.Shipment_Net_Weight
ELSE '0'
END
+ ' LBS'
+ 'Gross:
...
结果:将 varchar 值“LBS”转换为数据类型 int 时转换失败。
'Body' =
...
+ 'Net: ' +
CASE
WHEN wtpc.Reg_No IS NOT NULL THEN str(wtpc.Shipment_Net_Weight)
ELSE '0'
END
+ ' LBS'
+ 'Gross:
...
结果:将数据类型 varchar 转换为浮点数时出错。
'Body' =
...
+ 'Net: ' +
CASE
ELSE wtpc.Reg_No IS NOT NULL THEN
CONVERT(INT,
CASE
WHEN IsNumeric(CONVERT(VARCHAR(15), wtpc.Shipment_Net_Weight)) = 1
THEN CONVERT(VARCHAR(15),wtpc.Shipment_Net_Weight)
ELSE 0
END)
ELSE '0'
END
+ ' LBS'
+ 'Gross:
...
结果:将 varchar 值“LBS”转换为数据类型 int 时转换失败。这是从这个StackOverflow 问题中提取的
这是一个更完整的视图:
Declare @TempResults1 table(
ThisSubject nvarchar(max),
ThisTo nvarchar(max),
ThisCC nvarchar(max),
ThisBody nvarchar(max),
ThisBody2 nvarchar(max))
Insert into @TempResults1
Select
'Subject' =
isnull( @ShipmentNoString, '') + ' - ' + shpr.Last_Name + ', ' + shpr.First_Name + isnull(' - ' + @ModeString, '')
+ case
when cstm.broker_agent = -1 then ' - Foreign Port Agent Pre-Alert'
else ' - Port Agent Pre-Alert'
end,
... [To and CC are set here similiar to how the subject is set]
'Body' =
+ 'To: ' + vncb.Vendor_Name
+ 'Attn: ' +
case
when @GsaUsContact is not null then @GsaUsContact
else @GsaForContact
end
+ 'From: ' + usrs.Name
+ 'Date: ' + format(getdate(), 'ddMMyy')
... [More similar code]
+ 'Mode: ' + mode.Mode
+ 'Net: ' +
case
when wtpc.Reg_No is not null then CAST( wtpc.Shipment_Net_Weight AS varchar(15))
else '0'
end
+ ' LBS'
+ 'Gross: ' +
case
when wtpc.Reg_No is not null then CAST( wtpc.Shipment_Gross as varchar(15))
else '0'
end
+ ' 2LBS'
+ 'Cube: ' + isnull(wtpc.Shipment_CFT, '0') + ' CFT'
+ 'Pieces: ' +
case
when wtpc.Reg_No is not null then CAST(wtpc.Shipment_Piece_Count, varchar(15))
else '0'
end
+ ' PCS'
+ '<BR>'
+ 'OBL/AWB #: ' + asea.Mawb_Obl_No
...[More code like above with varchars]
+isnull('<b> Please send all correspondence to: ' + usrs.email + '.</b>', '')
,Body2 = null
解决方案
找到了修复:
isnull( convert(varchar(50), wtpc.Shipment_Net_Weight), '')
没有匹配的案例,但错误没有显示这一点,有点傻!谢谢大家的帮助!
推荐阅读
- java - 通过 Java 套接字发送图像
- node.js - PDF 在无服务器上运行的 node.js 上显示空白
- javascript - 将处于 redux 状态的对象存储为值
- r - 同一绘图上的多个 Pen 的游行图
- python - pandas - 根据列值复制每一行'n'次
- c++ - 在C++中继承时,受保护的方法可以成为私有方法吗?
- android - 数据的 getContentResolver() 值为 null 但正确接收名称
- python - 构建python代码以通过subprocess.Popen运行消息
- dialogflow-es - 如何处理同音异义词
- c - realloc():两次计算后下一个大小无效