国产亚洲精品a在线看。,骚货想不想被艹,国产麻豆剧传媒兔子先生,好大好爽好想要被操视频


昂捷論壇≡FAQ≡□-通用類 → 自定義表單數(shù)據(jù)表格里面數(shù)據(jù)統(tǒng)計的三種方法


  共有26342人關(guān)注過本帖樹形打印

主題:自定義表單數(shù)據(jù)表格里面數(shù)據(jù)統(tǒng)計的三種方法

帥哥喲,離線,有人找我嗎?
prcak47
  1樓 個性首頁 | 信息 | 搜索 | 郵箱 | 主頁 | UC


加好友 發(fā)短信
等級:超級管理員 帖子:145 積分:2648 威望:0 精華:0 注冊:2005/12/10 16:23:42
自定義表單數(shù)據(jù)表格里面數(shù)據(jù)統(tǒng)計的三種方法  發(fā)帖心情 Post By:2015/5/13 10:49:45

對于自定義表單的數(shù)據(jù)表格,常常要對其中的數(shù)據(jù)進(jìn)行數(shù)據(jù)統(tǒng)計,

我們推薦將腳本放在保存后執(zhí)行的腳本中進(jìn)行計算

下面有三種方法可以選擇

方法1,

統(tǒng)計出其中的數(shù)據(jù)列數(shù),然后用循環(huán)語句合計數(shù)值

 


 

declare  @eform_data table
(c_data xml)

insert into  @eform_data(c_data)
values('<rows>
  <row>
    <c_tab>
      <drows>
        <drow>
          <c_num>18000</c_num>
          <c_num>1000000</c_num>
          <c_num>18000</c_num>
        </drow>
      </drows>
    </c_tab>
  </row>
</rows>')

select * from @eform_data

declare @count varchar(20)
declare @sum money
declare @tsql nvarchar(1000)
declare @xmldata xml
set @sum = 0

select @count = cast(c_data.query('count(/rows/row/c_tab/drows/drow/c_num)') as varchar(20))
 from @eform_data
 
select @count

select @xmldata = c_data.query('(/rows/row/c_tab/drows/drow/c_num)')
 from @eform_data
 
while @count <> 0
begin

 select @tsql = 'select @sum = @sum + @xmldata.value(''(/c_num)['+@count+']'',''money'')'

 EXECUTE sp_executesql @tsql,N'@xmldata xml,@sum money out',@xmldata,@sum out

 set @count = @COUNT - 1
end

select @sum


 

方法2,直接用xml做統(tǒng)計運(yùn)算

 

declare @eform_data table
(c_data xml)


insert into  @eform_data(c_data)
values('<rows>
  <row>
    <c_tab>
      <drows>
        <drow>
          <c_num>18000</c_num>
          <c_num>1000000</c_num>
          <c_num>18000</c_num>
        </drow>
      </drows>
    </c_tab>
  </row>
</rows>')


select * from @eform_data

declare @sum money


select @sum= c_data.value('sum(/rows/row/c_tab/drows/drow/c_num)','money')
from @eform_data

select @sum

 

這個方法雖然語句簡潔,但是存在一個問題,就是當(dāng)數(shù)據(jù)合計超過百萬的時候,數(shù)據(jù)結(jié)果會變成科學(xué)計數(shù)法

導(dǎo)致轉(zhuǎn)換為money失敗

 

方法3

查詢出數(shù)據(jù)的xml,然后用字符串的運(yùn)算計算合集

 

declare @eform_data table
(c_data xml)

insert into  @eform_data(c_data)
values('<rows>
  <row>
    <c_tab>
      <drows>
        <drow>
          <c_num>18000</c_num>
          <c_num>1000000</c_num>
          <c_num>18000</c_num>
        </drow>
      </drows>
    </c_tab>
  </row>
</rows>')


select * from @eform_data

declare @sql varchar(1000)

select @sql = cast(c_data.query('(/rows/row/c_tab/drows/drow/c_num)') as varchar(1000))
from @eform_data


select @sql

select sum(cast(replace(c_str,'c_num>','') as money) )
from dbo.uf_split_string(@sql,'')
where c_str not in ('','/c_num>','')

 

 

 

 

 

[此貼子已經(jīng)被作者于2015/5/13 10:54:58編輯過]

使用IE9無法添加附件的解決方法 支持(0中立(0反對(0回到頂部
南平市| 镇安县| 囊谦县| 台东市| 汶川县| 东兰县| 拉萨市| 三河市| 邵武市| 麻江县| 南宫市| 兰坪| 新昌县| 汝南县| 小金县| 攀枝花市| 耿马| 鲜城| 石楼县| 卓资县| 临沧市| 阜康市| 郧西县| 扬州市| 寻乌县| 和静县| 徐水县| 安顺市| 平阴县| 兴海县| 获嘉县| SHOW| 彭泽县| 来凤县| 崇礼县| 衢州市| 武平县| 珠海市| 石屏县| 民和| 孟连|