Foxtable(狐表)用户栏目专家坐堂 → [求助]多表统计中来自多表分组的多表统计,帮我看一下,这样分组的代码对不对?


  共有8996人关注过本帖树形打印复制链接

主题:[求助]多表统计中来自多表分组的多表统计,帮我看一下,这样分组的代码对不对?

帅哥哟,离线,有人找我吗?
jk362223
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:一尾狐 帖子:422 积分:2708 威望:0 精华:0 注册:2012/2/10 18:12:00
[求助]多表统计中来自多表分组的多表统计,帮我看一下,这样分组的代码对不对?  发帖心情 Post By:2012/8/9 13:55:00 [只看该作者]

Dim bd1 As New SQLGroupTableBuilder("报销清单","长期医嘱")
bd1.C
Dim dt1 As fxDataSource
bd1.AddTable("长期医嘱","住次ID","住院主表","住次ID")
bd1.Groups.AddDef("{住院主表}.住次ID") '根据品名分组
bd1.Groups.AddDef("{住院主表}.姓名") '根据品名分组
bd1.Groups.AddDef("{住院主表}.参保方式") '根据品名分组
bd1.Groups.AddDef("{住院主表}.送报日期") '根据品名分组
bd1.Groups.AddDef("{长期医嘱}.项目ID") '根据品名分组
bd1.Groups.AddDef("{长期医嘱}.收费项目") '根据品名分组
bd1.Groups.AddDef("{长期医嘱}.项目类别") '根据型号分组
bd1.Groups.AddDef("{长期医嘱}.项目规格") '根据品名分组
bd1.Groups.AddDef("{长期医嘱}.单位") '根据型号分组
bd1.Groups.AddDef("{长期医嘱}.单价") '根据型号分组
bd1.Totals.AddExp("长期医嘱_报数","IIF([数量] >= 0,[数量],0)") '对数量进行统计
bd1.Totals.AddExp("长期医嘱_金额","IIF([数量] > 0,[数量] * [单价],0)") '对数量进行统计
dt1 = bd1.BuildDataSource()

Dim bd2 As New SQLGroupTableBuilder("统计表2","临时医嘱")
bd2.C
Dim dt2 As fxDataSource
bd2.AddTable("临时医嘱","住次ID","住院主表","住次ID")
bd2.Groups.AddDef("{住院主表}.住次ID") '根据品名分组
bd2.Groups.AddDef("{住院主表}.姓名") '根据品名分组
bd2.Groups.AddDef("{住院主表}.参保方式") '根据品名分组
bd2.Groups.AddDef("{住院主表}.送报日期") '根据品名分组
bd2.Groups.AddDef("{临时医嘱}.项目ID") '根据品名分组
bd2.Groups.AddDef("{临时医嘱}.收费项目") '根据品名分组
bd2.Groups.AddDef("{临时医嘱}.项目类别") '根据型号分组
bd2.Groups.AddDef("{临时医嘱}.项目规格") '根据品名分组
bd2.Groups.AddDef("{临时医嘱}.单位") '根据型号分组
bd2.Groups.AddDef("{临时医嘱}.单价") '根据型号分组
bd2.Totals.AddExp("临时医嘱_报数","IIF([开始日期] >= [报起始日期]And[开始日期] <= [报截止日期],[数量],0)") '对数量进行统计
bd2.Totals.AddExp("临时医嘱_金额","IIF([开始日期] >= [报起始日期]And[开始日期] <= [报截止日期],[数量] * [单价],0)") '对数量进行统计
dt2 = bd2.BuildDataSource()

Dim bd3 As New SQLGroupTableBuilder("统计表3","实验室记录")
bd3.C
Dim dt3 As fxDataSource
bd3.AddTable("实验室记录","住次ID","住院主表","住次ID")
bd3.Groups.AddDef("{住院主表}.住次ID") '根据品名分组
bd3.Groups.AddDef("{住院主表}.姓名") '根据品名分组
bd3.Groups.AddDef("{住院主表}.参保方式") '根据品名分组
bd3.Groups.AddDef("{住院主表}.送报日期") '根据品名分组
bd3.Groups.AddDef("{实验室记录}.项目ID") '根据品名分组
bd3.Groups.AddDef("{实验室记录}.收费项目") '根据品名分组
bd3.Groups.AddDef("{实验室记录}.项目类别") '根据型号分组
bd3.Groups.AddDef("{实验室记录}.项目规格") '根据品名分组
bd3.Groups.AddDef("{实验室记录}.单位") '根据型号分组
bd3.Groups.AddDef("{实验室记录}.单价") '根据型号分组
bd3.Totals.AddExp("实验室记录_报数","IIF([开始日期] >= [报起始日期]And[开始日期] <= [报截止日期],[数量],0)") '对数量进行统计
bd3.Totals.AddExp("实验室记录_金额","IIF([开始日期] >= [报起始日期]And[开始日期] <= [报截止日期],[数量] * [单价],0)") '对数量进行统计
dt3 = bd3.BuildDataSource()

 

Dim bd4 As New SQLGroupTableBuilder("统计表4","行为冲动")
bd4.C
Dim dt4 As fxDataSource
bd4.AddTable("行为冲动","住次ID","住院主表","住次ID")
bd4.Groups.AddDef("{住院主表}.住次ID") '根据品名分组
bd4.Groups.AddDef("{住院主表}.姓名") '根据品名分组
bd4.Groups.AddDef("{住院主表}.参保方式") '根据品名分组
bd4.Groups.AddDef("{住院主表}.送报日期") '根据品名分组
bd4.Groups.AddDef("{行为冲动}.项目ID") '根据品名分组
bd4.Groups.AddDef("{行为冲动}.收费项目") '根据品名分组
bd4.Groups.AddDef("{行为冲动}.项目类别") '根据型号分组
bd4.Groups.AddDef("{行为冲动}.项目规格") '根据品名分组
bd4.Groups.AddDef("{行为冲动}.单位") '根据型号分组
bd4.Groups.AddDef("{行为冲动}.单价") '根据型号分组
bd4.Totals.AddExp("行为冲动_报数","IIF([开始日期] >= [报起始日期]And[开始日期] <= [报截止日期],[数量],0)") '对数量进行统计
bd4.Totals.AddExp("行为冲动_金额","IIF([开始日期] >= [报起始日期]And[开始日期] <= [报截止日期],[数量] * [单价],0)") '对数量进行统计
dt4 = bd4.BuildDataSource()

Dim bd5 As New SQLGroupTableBuilder("统计表5","行为矫正")
bd5.C
Dim dt5 As fxDataSource
bd5.AddTable("行为矫正","住次ID","住院主表","住次ID")
bd5.Groups.AddDef("{住院主表}.住次ID") '根据品名分组
bd5.Groups.AddDef("{住院主表}.姓名") '根据品名分组
bd5.Groups.AddDef("{住院主表}.参保方式") '根据品名分组
bd5.Groups.AddDef("{住院主表}.送报日期") '根据品名分组
bd5.Groups.AddDef("{行为矫正}.项目ID") '根据品名分组
bd5.Groups.AddDef("{行为矫正}.收费项目") '根据品名分组
bd5.Groups.AddDef("{行为矫正}.项目类别") '根据型号分组
bd5.Groups.AddDef("{行为矫正}.项目规格") '根据品名分组
bd5.Groups.AddDef("{行为矫正}.单位") '根据型号分组
bd5.Groups.AddDef("{行为矫正}.单价") '根据型号分组
bd5.Totals.AddExp("行为矫正_报数","IIF([开始日期] >= [报起始日期]And[开始日期] <= [报截止日期],[数量],0)") '对数量进行统计
bd5.Totals.AddExp("行为矫正_金额","IIF([开始日期] >= [报起始日期]And[开始日期] <= [报截止日期],[数量] * [单价],0)") '对数量进行统计
dt5 = bd5.BuildDataSource()

Dim bd6 As New SQLGroupTableBuilder("统计表6","行为观察")
bd6.C
Dim dt6 As fxDataSource
bd6.AddTable("行为观察","住次ID","住院主表","住次ID")
bd6.Groups.AddDef("{住院主表}.住次ID") '根据品名分组
bd6.Groups.AddDef("{住院主表}.姓名") '根据品名分组
bd6.Groups.AddDef("{住院主表}.参保方式") '根据品名分组
bd6.Groups.AddDef("{住院主表}.送报日期") '根据品名分组
bd6.Groups.AddDef("{行为观察}.项目ID") '根据品名分组
bd6.Groups.AddDef("{行为观察}.收费项目") '根据品名分组
bd6.Groups.AddDef("{行为观察}.项目类别") '根据型号分组
bd6.Groups.AddDef("{行为观察}.项目规格") '根据品名分组
bd6.Groups.AddDef("{行为观察}.单位") '根据型号分组
bd6.Groups.AddDef("{行为观察}.单价") '根据型号分组
bd6.Totals.AddExp("行为观察_报数","IIF([开始日期] >= [报起始日期]And[开始日期] <= [报截止日期],[数量],0)") '对数量进行统计
bd6.Totals.AddExp("行为观察_金额","IIF([开始日期] >= [报起始日期]And[开始日期] <= [报截止日期],[数量] * [单价],0)") '对数量进行统计
dt6 = bd6.BuildDataSource()

Dim bd7 As New SQLGroupTableBuilder("统计表7","量表首诊")
bd7.C
Dim dt7 As fxDataSource
bd7.AddTable("量表首诊","住次ID","住院主表","住次ID")
bd7.Groups.AddDef("{住院主表}.住次ID") '根据品名分组
bd7.Groups.AddDef("{住院主表}.姓名") '根据品名分组
bd7.Groups.AddDef("{住院主表}.参保方式") '根据品名分组
bd7.Groups.AddDef("{住院主表}.送报日期") '根据品名分组
bd7.Groups.AddDef("{量表首诊}.项目ID") '根据品名分组
bd7.Groups.AddDef("{量表首诊}.收费项目") '根据品名分组
bd7.Groups.AddDef("{量表首诊}.项目类别") '根据型号分组
bd7.Groups.AddDef("{量表首诊}.项目规格") '根据品名分组
bd7.Groups.AddDef("{量表首诊}.单位") '根据型号分组
bd7.Groups.AddDef("{量表首诊}.单价") '根据型号分组
bd7.Totals.AddExp("量表首诊_报数","IIF([开始日期] >= [报起始日期]And[开始日期] <= [报截止日期],[数量],0)") '对数量进行统计
bd7.Totals.AddExp("量表首诊_金额","IIF([开始日期] >= [报起始日期]And[开始日期] <= [报截止日期],[数量] * [单价],0)") '对数量进行统计
dt7 = bd7.BuildDataSource()

Dim bd8 As New SQLGroupTableBuilder("统计表8","量表护士观察")
bd8.C
Dim dt8 As fxDataSource
bd8.AddTable("量表护士观察","住次ID","住院主表","住次ID")
bd8.Groups.AddDef("{住院主表}.住次ID") '根据品名分组
bd8.Groups.AddDef("{住院主表}.姓名") '根据品名分组
bd8.Groups.AddDef("{住院主表}.参保方式") '根据品名分组
bd8.Groups.AddDef("{住院主表}.送报日期") '根据品名分组
bd8.Groups.AddDef("{量表护士观察}.项目ID") '根据品名分组
bd8.Groups.AddDef("{量表护士观察}.收费项目") '根据品名分组
bd8.Groups.AddDef("{量表护士观察}.项目类别") '根据型号分组
bd8.Groups.AddDef("{量表护士观察}.项目规格") '根据品名分组
bd8.Groups.AddDef("{量表护士观察}.单位") '根据型号分组
bd8.Groups.AddDef("{量表护士观察}.单价") '根据型号分组
bd8.Totals.AddExp("量表护士观察_报数","IIF([开始日期] >= [报起始日期]And[开始日期] <= [报截止日期],[数量],0)") '对数量进行统计
bd8.Totals.AddExp("量表护士观察_金额","IIF([开始日期] >= [报起始日期]And[开始日期] <= [报截止日期],[数量] * [单价],0)") '对数量进行统计
dt8 = bd8.BuildDataSource()

Dim bd9 As New SQLGroupTableBuilder("统计表9","量表TESS")
bd9.C
Dim dt9 As fxDataSource
bd9.AddTable("量表TESS","住次ID","住院主表","住次ID")
bd9.Groups.AddDef("{住院主表}.住次ID") '根据品名分组
bd9.Groups.AddDef("{住院主表}.姓名") '根据品名分组
bd9.Groups.AddDef("{住院主表}.参保方式") '根据品名分组
bd9.Groups.AddDef("{住院主表}.送报日期") '根据品名分组
bd9.Groups.AddDef("{量表TESS}.项目ID") '根据品名分组
bd9.Groups.AddDef("{量表TESS}.收费项目") '根据品名分组
bd9.Groups.AddDef("{量表TESS}.项目类别") '根据型号分组
bd9.Groups.AddDef("{量表TESS}.项目规格") '根据品名分组
bd9.Groups.AddDef("{量表TESS}.单位") '根据型号分组
bd9.Groups.AddDef("{量表TESS}.单价") '根据型号分组
bd9.Totals.AddExp("量表TESS_报数","IIF([开始日期] >= [报起始日期]And[开始日期] <= [报截止日期],[数量],0)") '对数量进行统计
bd9.Totals.AddExp("量表TESS_金额","IIF([开始日期] >= [报起始日期]And[开始日期] <= [报截止日期],[数量] * [单价],0)") '对数量进行统计
dt9 = bd9.BuildDataSource()

Dim nms As String() = {"住次ID","姓名","参保方式","送报日期","项目ID","收费项目","项目类别","项目规格","单位","单价"}
dt1.Combine(nms,dt2,nms)'将销售统计数据组合到进货统计数据
dt1.Combine(nms,dt3,nms)'将销售统计数据组合到进货统计数据
dt1.Combine(nms,dt4,nms)'将销售统计数据组合到进货统计数据
dt1.Combine(nms,dt5,nms)'将销售统计数据组合到进货统计数据
dt1.Combine(nms,dt6,nms)'将销售统计数据组合到进货统计数据
dt1.Combine(nms,dt7,nms)'将销售统计数据组合到进货统计数据
dt1.Combine(nms,dt8,nms)'将销售统计数据组合到进货统计数据
dt1.Combine(nms,dt9,nms)'将销售统计数据组合到进货统计数据
dt1.Show("报销清单")


With DataTables("报销清单").DataCols  '用表达式列计算库存数据
    .Add("数量",Gettype(Integer), "IsNull([长期医嘱_报数],0) + ISNULL([临时医嘱_报数],0)")
    .Add("金额",Gettype(Double), "IsNull([长期医嘱_金额],0) + ISNULL([临时医嘱_金额],0)")
MainTable = Tables("报销清单") '打开生成的统计表
End With

 

Tables("报销清单").OpenView("报销清单")

Dim Cols1() As String = {"住次ID","姓名","参保方式","送报日期","项目ID","收费项目","项目类别","项目规格","单位","单价","长期医嘱_报数","长期医嘱_金额","临时医嘱_报数","临时医嘱_金额","实验室记录_报数","实验室记录_金额","行为冲动_报数","行为冲动_金额","行为矫正_报数","行为矫正_金额","行为观察_报数","行为观察_金额","量表首诊_报数","量表首诊_金额","量表护士观察_报数","量表护士观察_金额","量表TESS_报数","量表TESS_金额","数量","金额"}
Dim Cols2() As String = {"住次ID","姓名","参保方式","送报日期","项目ID","收费项目","项目类别","项目规格","单位","单价","长期医嘱_报数","长期医嘱_金额","临时医嘱_报数","临时医嘱_金额","实验室记录_报数","实验室记录_金额","行为冲动_报数","行为冲动_金额","行为矫正_报数","行为矫正_金额","行为观察_报数","行为观察_金额","量表首诊_报数","量表首诊_金额","量表护士观察_报数","量表护士观察_金额","量表TESS_报数","量表TESS_金额","数量","金额"}
For Each dr1 As DataRow In DataTables("报销清单").Select("[金额] > 0")   
    Dim dr2 As DataRow = DataTables("动态报次清单").AddNew()
    For i As Integer = 0 To Cols1.Length -1
        dr2(Cols2(i)) = dr1(Cols1(i))
    Next
Next

 

 下载信息  [文件大小:   下载次数: ]
点击浏览该文件:za20120720.zip


 回到顶部
帅哥哟,离线,有人找我吗?
jk362223
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:一尾狐 帖子:422 积分:2708 威望:0 精华:0 注册:2012/2/10 18:12:00
  发帖心情 Post By:2012/8/9 13:59:00 [只看该作者]

可能分组代码不对,不能统计出,要是代对的话,报销清单不显示的代码如何写,请教我!

 回到顶部