在表中保存空字符串

时间:2015-02-18 07:37:03

标签: javascript sql-server node.js node-mssql

我有一个网站,其中包含一个完整设置的表单,其中每个输入都在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]));
        }
    });
});

2 个答案:

答案 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