您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

如何获得一个箱子大小的总重量,例如12 x 160g等于1.92kg

如何获得一个箱子大小的总重量,例如12 x 160g等于1.92kg

通过@Tomalak添加到注释中,下面是一个示例脚本,您可以使用该脚本来填充重量表达转换表。

CREATE TABLE dbo.Weights(
     Weight varchar(20) NOT NULL 
        CONSTRAINT PK_Weights PRIMARY KEY
    ,weightingrams int NULL
    ,WeightInKilograms AS CAST(weightingrams / 1000.0 AS decimal(10, 2))
);
GO

INSERT INTO dbo.Weights(Weight)
    SELECT DISTINCT Weight
    FROM dbo.Foo;
GO

DECLARE
      @Weight varchar(20)
    , @weightingrams int
    , @sqlExpression nvarchar(MAX);
DECLARE foo CURSOR LOCAL FAST_FORWARD FOR
    SELECT weight
    FROM dbo.Weights;
OPEN foo;
WHILE 1 = 1
BEGIN

    FETCH NEXT FROM foo INTO @Weight;

    IF @@FETCH_STATUS = -1 BREAK;

    BEGIN TRY

        SET @sqlExpression = 'SET @weightingrams = 
            ' + REPLACE(REPLACE(REPLACE(@Weight, 'x', '*'), 'kg', '000'), 'g', '');

        EXEC sp_executesql @sqlExpression
            , N'@weightingrams int OUTPUT'
            , @weightingrams = @weightingrams OUTPUT;

    END TRY
    BEGIN CATCH

        SET @weightingrams = NULL;

    END CATCH;

    UPDATE dbo.Weights
    SET weightingrams = @weightingrams
    WHERE Weight = @Weight;

END
CLOSE foo;
DEALLOCATE foo;
GO
其他 2022/1/1 18:47:47 有684人围观

撰写回答


你尚未登录,登录后可以

和开发者交流问题的细节

关注并接收问题和回答的更新提醒

参与内容的编辑和改进,让解决方法与时俱进

请先登录

推荐问题


联系我
置顶