テーブルやクエリに含まれる列(フィールド)で、指定した列に記録されている数値の合計値を返します。Avg関数に似ていますが、グループ化を併用せず利用でき、対象とするテーブルや行(レコード)も簡単に指定する(絞り込む)ことができるため扱いやすいというメリットがあります。
使用例
数学点数平均: DAvg("数学点数","成績テーブル")
データシートビューです。数学の点数の平均値である62.7777777777778が得られています
Avg関数の場合、他の列のそれぞれの行を表示しながら平均値を表示するためにはサブクエリを使う必要がありましたが、DAvg関数だと関数だけで実現できます。
上記テーブルに基づく実行結果の例をいくつか挙げてみます。
表記例 | 出力例 | 説明 |
---|---|---|
DAvg("数学点数","成績テーブル") | 62.7777777777778 | |
DAvg("英語点数","成績テーブル") | 68.8571428571429 | 指定した列の値にNullが含まれる場合は、そのレコードが計算から除外されます |
DAvg(50,"成績テーブル") | 50 | 直接数値を指定した場合、全レコードにその値があるものとして計算された平均値が返されます。結果的に指定した値そのものが返されます |
DAvg("数学点数","成績テーブル","受験番号>=3") | 61.5714285714286 | 集計の対象となるレコードの条件を指定することが出来ます |
DAvg("英語点数","成績テーブル","受験番号>=3") | 66.8 |
書式
DAvg(列名,レコードセット名[,条件])
列名はダブルクォーテーション(")で囲む必要があります。
レコードセットにはテーブルやレコードの名前をやはりダブルクォーテーションで囲って指定します。
条件は対象となるレコードを絞り込むためのものですが、省略できます。
備考
特にクエリでの使用において、グループ化を考慮する必要がなく、他のテーブルやクエリの値も容易に集計できますので使い勝手がよいですが、レコード数が多い場合などは実行に時間がかかる場合があります。クエリで利用する場合、そのテーブルやクエリをクエリデザイン画面上に表示しなくとも値を取得することが出来ます。