数据库中有一个非常简单的表,其中包含公制单位转换,如下所示:
| UnitFrom | UnitTo | Scale |
| m | mm | 1000 |
| m | cm | 100 |
etc.
我在考虑创建一个函数来转换基于输入(unit,fromunit,tounit)的表中计算转换的单位。
例如 Conv_Units(0.1, 'm', 'cm')
返回100。
这有可能吗?我的想法如下,但不起作用:
CREATE FUNCTION dbo.Conv_Units
(
[@Unit] float
, [@FromUnit] nvarchar(20)
, [@ToUnit] nvarchar(20)
);
RETURNS float
AS
BEGIN
DECLARE @ConvUnit float;
DECLARE @Unit float;
DECLARE @FromUnit nvarchar(20);
DECLARE @ToUnit nvarchar(20);
DECLARE @Scale float = (select Scale from dbo.UnitsConversion where FromUnit = @FromUnit and ToUnit = @ToUnit);
SELECT @ConvUnit = @Unit * @Scale
RETURN @ConvUnit
END
GO
1条答案
按热度按时间hivapdat1#
感谢@gserg的解决方案。
就是这样: