Access交流网
  • 设为首页|收藏本站|繁体中文|手机版
  •     
  • Access培训-Access开发平台-Access行业开发

  • 首页
  • 资讯
  • 技巧
  • 源码
  • 行业
  • 资源
  • 活动
  • 关于

技巧

ACCESS数据库

启动/设置/选项/背景

修复/压缩

安全/加密/解密

快捷键

版本升级/其它等

数据表

命名方式/设计规范

表设计

查询

Sql语言基础

选择查询

更新查询

删除查询

追加查询

生成表查询

交叉表查询

SQL特定查询

查询参数

查询综合应用

界面/窗体/控件

标签

文本框

命令按钮

组合框/列表框

选项组/复选框/选项按钮

选项卡

子窗体

窗体本身/综合应用

其它

报表打印

报表设计

高级报表

模块/函数/VBA/API/系统

VBA基础

内置函数

调试/跟踪/Debug

模块/类模块

API/COM/系统相关

字符数字日期

网络通信游戏

加密解密安全

文件处理

经典算法

宏/菜单/工具栏/功能区

宏/脚本

菜单/工具栏

功能区/Ribbon

图表/图形/图像/多媒体

图表

图形/图像

音频

视频/动画

DAO/链接表/ADO/ADP

DAO/链接表/ODBC

ADO/RDO

ADP

ActiveX/第三方控件/插件

Treeview树控件

ListView列表控件

Toolbar工具栏控件

微软其它控件

Dbi-Tech

CodeJock

Grid++Report

FastReport

ComponentOne

加载项/插件/Addin

OFFICE集成/导入导出/交互

Excel导入导出/交互

Word导入导出/交互

PPT交互

Outlook控制/邮件

Text文本文件/INI/CSV

PDF/SWF/XML格式

CAD格式

Sharepoint/其它Office

SqlServer/其它数据库

表

视图

存储过程/触发器

函数

用户/权限/安全

调试/维护

SqlServer其它/综合

发布/打包/文档/帮助

开发版/运行时

打包/发布/部署

开发文档/帮助制作

Access完整行业系统

采购管理系统

销售管理系统

仓库管理系统

人力资源管理HRM

CRM管理系统

MRP/ERP管理系统

BRP/流程优化

其它管理系统

心得/经验/绝招
其它/杂项
Excel技巧

Excel应用与操作

Excel开发编程

Word技巧

Word应用与操作

Word开发编程

Outlook技巧

Outlook应用与操作

Outlook开发编程

热门文章

  • 如何用sql查询获取表得信..
  • 一个排名的例子
  • 根据要求去掉最大与最小的数..
  • 如何在VBA中编写含有变量..
  • VBA代码打开或关闭表和查..
  • Access 2007通过..

最新文章

  • Access联合查询实例解..
  • Access在查询中使用公..
  • 统计本月最大与上月最大值之..
  • 如何在VBA中编写含有变量..
  • Access以只读方式或新..
  • VBA代码打开或关闭表和查..

联系方式

Access交流网(免费Access交流)

QQ:18449932 

网  址:www.access-cn.com

当前位置:首页 > 技巧 > 查询 > 查询综合应用
查询综合应用

VBA代码打开或关闭表和查询的数据表视图中的合计行(列汇总)

手工显示合计行(列汇总) 我们都知道如何操作,可参考:

  http://www.access-cn.com/info/3587-cn.html

合计行可选的聚合函数

http://www.access-cn.com/info/3588-cn.html


那如何VBA代码设置表和查询的数据表视图中的合计行(汇总行)


1.VBA代码设置表的数据表视图中的合计行:


   db.TableDefs("table1").Properties("TotalsRow") = True


Public Function IsTotalsRowVisible(sTableName As String) As Boolean
    Dim db As DAO.Database
    Dim td As DAO.TableDef
    Set db = CurrentDb()
    set td = db.TableDefs(sTableName)
    IsTotalsRowVisible = (td.Properties("TotalsRow") = True)
End Function


Public Function IsTotalsRowVisible(sTableName As String) As Boolean
    Dim db As DAO.Database
    Dim td As DAO.TableDef
    
    Set db = CurrentDb()
    Set td = db.TableDefs(sTableName)
    
    On Error Resume Next
    IsTotalsRowVisible = (td.Properties("TotalsRow") = True)
    
    ' if the TotalsRow property does not exist then return false
    If (Err = 3270) Then
        IsTotalsRowVisible = False
    ElseIf (Err <> 0) Then
        Stop
    End If
    On Error GoTo 0
End Function
Sub test()
    Dim db As DAO.Database
    Dim td As DAO.TableDef
    
    Set db = CurrentDb()
    
    ' test all non-system tables
    For Each td In db.TableDefs
        If (Not (td.Name Like "MSys*")) Then
            Debug.Print td.Name, IsTotalsRowVisible(td.Name)
        End If
    Next
    
    db.Close
    Set db = Nothing
    Set td = Nothing
End Sub


2. 用代码打开或关闭查询的数据表视图的合计行 total row:


Set qrydef = CurrentDb.QueryDefs("MyQueryName")

qrydef.Properties.Append qrydef.CreateProperty("TotalsRow", dbBoolean, True)  '可以再加个判断,如果属性存在,则直接 qrydef.Properties("TotalsRow")=true


qrydef.Fields(1).Properties("AggregateType").Value = 0 'add the Aggregate Total on field 1
qrydef.Fields(2).Properties("AggregateType").Value = 1 'add the Average Total on field 2
qrydef.Fields(3).Properties("AggregateType").Value = 2 'add the Count Total on field 3

         

相关代码:

 Function LoopQuery(ByVal tempProj As Double)
Dim strSQL As String 
Dim qdfTemp As QueryDef 
Dim ProjNumb As Double 
ProjNumb = tempProj
strSQL = "sql code...."
With CurrentDb
Set qdfTemp = .CreateQueryDef(ProjNumb, strSQL)
 qdfTemp.Fields(21).Properties("AggregateType").Value = 0 'add the Aggregate Total on Total Hours
 qdfTemp.Fields(23).Properties("AggregateType").Value = 0 'add the Aggregate Total on Total Costs
 qdfTemp.Fields(24).Properties("AggregateType").Value = 0 'add the Aggregate Total on Total Discounted 
End With


Set qdfTemp = .CreateQueryDef(ProjNumb, strSQL)
qdfTemp.Properties.Append _
qdfTemp.CreateProperty("TotalsRow", dbBoolean, True)


Dim pSQL as String

set pSQL = "...."

Dim db As DAO.Database ' database decleration

Set db = CurrentDb ' use current

Dim qdf As QueryDef 'for the query sourceobject

Set qdf = CurrentDb.CreateQueryDef("qtemp", pSQL) ' make QueryDef

Dim prop As DAO.Property ' property for the fields

'At this point, fields do not have a property called AggregateType

'Lets create one

Set prop = qdf.fields("Merged").CreateProperty("AggregateType", dbInteger, 0) ' make property

qdf.fields("Merged").Properties.Append prop ' assign it to field

Set prop = qdf.fields("Imported").CreateProperty("AggregateType", dbInteger, 0)

qdf.fields("Imported").Properties.Append prop

Set prop = qdf.fields("Count").CreateProperty("AggregateType", dbInteger, 0)

qdf.fields("Count").Properties.Append prop


'currently, the QueryDef doesn't have a TotalsRow property.

'Lets make one for it

qdf.Properties.Append qdf.CreateProperty("TotalsRow", dbBoolean, True)

qdf.fields.Refresh ' probably not needed


3. 但针对子窗体 数据表视图 却无法 控制,只能


  1. 先在设计视图,先手工打开显示合计行。 me.recordset.properties("Totalrow") = True  只会影响窗体绑定的表或查询的的汇总方式,而不是窗体数据视图本身。(即如果窗体绑定的查询设置了合计,则msgbox me.recordset.properties("Totalrow") 结果为True.  与窗体的合计行显示没有关系)

  2. 再用代码控制 每个字段的合计方式: me.controls("fieldname").Properties("AggregateType") = 0

    in design mode of the form. 
    me.formname.form.recordset.properties("Totalrow") = True
    for this part open the form in design mode and enable the total row using the method msdn and microsoft says to do.

    now if you want to set the aggreation at run time. you can. 
    on form open event..
    me.controls("fieldname").Properties("AggregateType") = 0 gives you Sum
    but you can use -1 to turn it off.
    1 give you the next one in the list.
    any got this to open a form and apply sum to the fields that I wanted it to be applied.


发布人:zstmtony  
分享到:
点击次数:  更新时间:2017-02-09 12:38:27  【打印此页】  【关闭】
上一条:Access RunCommands 列表大全  下一条:Access 表和查询 数据表视图的合计行计算可使用的聚合函数



相关文章

  • • Access联合查询实例解析
  • • Access在查询中使用公共函数
  • • 统计本月最大与上月最大值之差
  • • 如何在VBA中编写含有变量的SQL语句而不易出错
  • • Access以只读方式或新增方式打开数据表或查询
  • • Access 表和查询 数据表视图的合计行计算可使用的聚合函数
  • • Access如何在数据表(表或查询)中显示列汇总(汇总行)

热门文章

  • [2017-02-08] 显示和隐藏查询结果中的列汇总access数据库
  • [2008-12-08] 根据要求去掉最大与最小的数据,然后求平均分access数据库
  • [2004-08-18] vba和查询结合的例子,以开拓思路。access数据库
  • [2004-08-18] 记录合并的例子,以开拓思路.access数据库
  • [2017-02-09] VBA代码打开或关闭表和查询的数据表视图中的合计行(列汇总)access数据库
  • [2017-08-18] Access联合查询实例解析access数据库

热门产品

公司动态|在线留言|在线反馈|友情链接|会员中心|站内搜索|网站地图

Access交流网 版权所有 1999-2018 粤ICP备10043721号

QQ:18449932

Access应用 Access培训 Access开发 Access平台

access|数据库|access下载|access教程|access视频|access软件

Powered by MetInfo 5.3.12 ©2008-2023  www.metinfo.cn