Warning: file_get_contents(/data/phpspider/zhask/data//catemap/7/sql-server/23.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Sql 类似于的引用,如'12 x 160',然后是1.92。最好的方法可能是创建一个两列辅助表,将'12 x 160g'等值解析为1.92。填写主表中的选择DISTINCT,并手动提供所有计算结果。然后,您可以针对该表进行联接,并完全跳过任何在线计算。当然,只有_Sql_Sql Server - Fatal编程技术网

Sql 类似于的引用,如'12 x 160',然后是1.92。最好的方法可能是创建一个两列辅助表,将'12 x 160g'等值解析为1.92。填写主表中的选择DISTINCT,并手动提供所有计算结果。然后,您可以针对该表进行联接,并完全跳过任何在线计算。当然,只有

Sql 类似于的引用,如'12 x 160',然后是1.92。最好的方法可能是创建一个两列辅助表,将'12 x 160g'等值解析为1.92。填写主表中的选择DISTINCT,并手动提供所有计算结果。然后,您可以针对该表进行联接,并完全跳过任何在线计算。当然,只有,sql,sql-server,Sql,Sql Server,类似于的引用,如'12 x 160',然后是1.92。最好的方法可能是创建一个两列辅助表,将'12 x 160g'等值解析为1.92。填写主表中的选择DISTINCT,并手动提供所有计算结果。然后,您可以针对该表进行联接,并完全跳过任何在线计算。当然,只有当值不是到处都是,而是形成一个有限的集合时,这才是可行的。@Tomalak是的,这听起来是一个不错的方法。我现在就开始,为解决方案干杯。你的专栏是数据库误用的一个主要例子。它应该至少有3个独立的列:值、单位、乘数。与其尝试编写SQL来计算这个专



类似于
的引用,如'12 x 160',然后是1.92
。最好的方法可能是创建一个两列辅助表,将
'12 x 160g'
等值解析为
1.92
。填写主表中的
选择DISTINCT
,并手动提供所有计算结果。然后,您可以针对该表进行联接,并完全跳过任何在线计算。当然,只有当值不是到处都是,而是形成一个有限的集合时,这才是可行的。@Tomalak是的,这听起来是一个不错的方法。我现在就开始,为解决方案干杯。你的专栏是数据库误用的一个主要例子。它应该至少有3个独立的列:值、单位、乘数。与其尝试编写SQL来计算这个专栏,不如尝试改变你的数据库设计,一劳永逸地解决混乱的数据。Hi@Tomalak-这个数据库设计是由其他人创建的,它是这样设计的,这让人非常沮丧,所以我完全同意你在中添加这些专栏。它本质上是一个来自外部公司的仓库管理系统,但我正在使用他们的数据创建我们自己的软件,以满足我们的需求。我得和他们联系,看看能不能改一下。但同时,当引用像'12 x 160'然后是1.92时,我可能需要硬编码像
这样的东西。可能最好的方法是创建一个两列帮助表,将像
'12 x 160g'
这样的值解析为
1.92
。填写主表中的
选择DISTINCT
,并手动提供所有计算结果。然后,您可以针对该表进行联接,并完全跳过任何在线计算。当然,只有当值不是到处都是,而是形成一个有限的集合时,这才是可行的。@Tomalak是的,这听起来是一个不错的方法。我现在就开始,为解决方案干杯。不适用于
10 x 25kg
。不适用于
10 x 25kg
。出于好奇,在这里使用
sp_executesql
有什么好处?我会使用
进行更新
光标…或者使用插入查询来选择任何缺少的行并进行计算,仔细想想。@Tomalak,我只使用
sp_executesql
来计算值。也可以使用可更新的游标。我的回答是作为一个起点,可以根据需要进行扩展。公平地说,我只是想看看这里是否有我不知道的东西。出于好奇,在这里使用
sp_executesql
有什么好处?我会使用
进行更新
光标…或者使用插入查询来选择任何缺少的行并进行计算,仔细想想。@Tomalak,我只使用
sp_executesql
来计算值。也可以使用可更新的游标。我的回答是作为一个起点,可以根据需要进行扩展。公平地说,我只是想看看这里是否有我不知道的东西。
12 x 60g
12 x 160g
500g
1kg
1kg
12 x 160g
12 x 250g
0.72kg  /* 12 x 0.060 = 0.72 */
1.92kg  /* 12 x 0.160 = 1.92 ... */
0.5kg
1kg
1kg
1.92kg
3kg
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