首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 数据库 > SQL Server >

两个计算出来的字段怎么进行除法

2013-10-25 
两个计算出来的字段如何进行除法SELECT [LoadingOne] as 装车人,总装车费dbo.zxhuo(KaName,Brand,1,Goods

两个计算出来的字段如何进行除法
SELECT [LoadingOne] as 装车人
      ,总装车费=dbo.zxhuo(KaName,Brand,1,GoodsTon,0,0),装车人数=dbo.CreateListFromStr(LoadingOne) where.....
现在我想得到   平均装车费= 总装车费/装车人数 的数据,如果
平均装车费=dbo.zxhuo(KaName,Brand,1,GoodsTon,0,0)/dbo.CreateListFromStr(LoadingOne)
这样数据库就计算两遍了,这样不好吧


[解决办法]

在语句的外面,包一层就行了哈,这样,在外层计算平均装车费的时候,就不会重复再次计算:总装车费和装车人数了,而是利用了内层已经计算出来的:总装车费和装车人数。



select 装车人,
       总装车费,
       装车人数,
       平均装车费= 总装车费/装车人数
from 
(
SELECT [LoadingOne] as 装车人
      ,总装车费=dbo.zxhuo(KaName,Brand,1,GoodsTon,0,0),
      装车人数=dbo.CreateListFromStr(LoadingOne) 
where.....
)t


[解决办法]
我说点与问题无关的吧。。。在大结果集的情况下楼主这种调用函数的方式会极大的降低效率,推荐再好好分析一下函数的功能,尽量用链接来完成计算。。

热点排行