我有一个网站,其中包含一个完整设置的表单,其中每个输入都在MS SQL数据库中保存一个值。
但是当我将字段设置为''时,我收到以下错误消息: “传入的表格数据流(TDS)远程过程调用(RPC)协议流不正确。参数3(”“):数据类型0x00未知。”
我的node.js服务调用一个如下所示的存储过程:
CREATE PROCEDURE [dbo].[ckd_Configurations_Update]
@Key NVARCHAR(256),
@Value NVARCHAR(MAX)
AS
BEGIN
UPDATE [dbo].[ckd_Configurations] SET [Value]=@Value WHERE [Key]=@Key;
END
我的表:
CREATE TABLE [dbo].[ckd_Configurations]
(
[Key] NVARCHAR(256) NOT NULL PRIMARY KEY,
[Value] NVARCHAR(MAX)
)
最后我的node.js路由设置配置:
router.post('/configurations/update', function (req, res) {
var request = new sql.Request(databaseConnection);
var configuration = req.body;
request.input('Key', sql.NVarChar(256), configuration.Key);
request.input('Value', sql.NVarChar(sql.MAX), configuration.Value);
request.execute('ckd_Configurations_Update', function (error, recordsets) {
if (error) {
res.json(new apiResponse(false, error.message));
} else {
res.json(new apiResponse(true, '', recordsets[0]));
}
});
});
答案 0 :(得分:1)
将mssql更新为2.0。此版本已解决此问题。
答案 1 :(得分:0)
如果我理解你的问题,你希望能够在数据库中插入空字符串吗?
允许' NULL'在表格中对价值列。这样就可以设置null值。在存储过程中,输入一个条件:
IF @Value = ''
BEGIN
SET @Value = NULL
END
如果要将值作为空字符串返回,可以在SELECT语句中使用它。
Select isnull(Value, '') as Value from [ckd_Configurations]
将字符值设置为' -1'然后在存储过程中检查它并将其设置为NULL。我认为这里的问题是您的服务不接受导致问题的空字符串。在存储过程中,您还可以设置
@Value NVARCHAR(MAX) = NULL