За допомогою функцій DStDev і DStDevP можна оцінити стандартне відхилення для набору значень у вказаному наборі записів ( домен ). Використовуйте функції DStDev і DStDevP в модулі Visual Basic for Applications (VBA), макрос, виразі запиту або обчислюваний елемент керування у формі чи звіті.
Використовуйте функцію DStDevP, щоб оцінити сукупність, і функцію DStDev, щоб оцінити вибірку із сукупності.
Наприклад, за допомогою функції DStDev ви можете обчислити в модулі стандартне відхилення для набору оцінок учнів за контрольні роботи.
Синтаксис
DStDev ( expr , domain [, criteria] )
DStDevP ( expr , domain [, criteria] )
Функції DStDev і DStDevP мають такі аргументи:
Аргумент |
Опис |
expr |
Обов’язковий аргумент. Вираз, що визначає числове поле, за яким потрібно знайти стандартне відхилення. Це може бути рядковий вираз, який визначає поле в таблиці чи запиті, або вираз, який обчислює дані в цьому полі. В аргументі expr можна вказати ім’я поля в таблиці, елемента керування у формі, константи або функції. Якщо аргумент expr включає функцію, вона може бути вбудованою або користувацькою, але не може бути іншою агрегатною функцією домену чи агрегатною функцією SQL. |
домен |
Обов’язковий аргумент. Рядковий вираз, який визначає набір записів, щоб складають домен. Це може бути ім’я таблиці або ім’я запиту, у якого немає обов’язкових параметрів. |
умови |
— необов’язковий аргумент. Рядковий вираз, який використовується для обмеження діапазону даних, до якого застосовується функція DStDev або DStDevP . Наприклад, умови часто еквівалентні речелю WHERE у виразі SQL без слова WHERE. Якщо аргумент criteria не вказано, функції DStDev і DStDevP оцінюють вираз для всього домену. Будь-яке поле, включене до умов , також має бути полем у домені; Інакше функції DStDev і DStDevP повертатимуть Null-значення. |
Примітки
Якщо аргумент domain посилається менше ніж на два записи або якщо менше двох записів задовольняють умови в аргументі criteria, функції DStDev і DStDevP повертають Null-значення. Це означає, що стандартне відхилення не обчислюється.
Де б не використовувалася функція DStDev або DStDevP (у макросі, модулі, виразі запиту чи обчислюваному елементі керування), аргумент criteria потрібно створювати дуже уважно, щоб він обчислювався правильно.
За допомогою функцій DStDev і DStDevP ви можете задати умову в рядку "Criteria" запиту на вибірку. Наприклад, ви можете створити запит для таблиць "Замовлення" і "Продукти", щоб відобразити всі продукти, для яких вартість доставки впала вище середнього значення зі стандартним відхиленням для вартості доставки. Рядок "Criteria" під полем "Freight" міститиме такий вираз:
>(DStDev("[Freight]", "Orders") + DAvg("[Freight]", "Orders"))
Функції DStDev і DStDevP можна використовувати у виразі обчислюваного поля запиту або в рядку Оновлення до запит на оновлення.
Примітка.: У виразі обчислюваного поля запит підсумків можна використовувати функції DStDev і DStDevP або StDev і StDevP . Якщо використовується функція DStDev або DStDevP , значення обчислюються до згрупування даних. Якщо використовується функція StDev або StDevP , дані згрупуються перед обчисленням значень у виразі поля.
В обчислюваному елементі керування використовуйте функції DStDev і DStDevP, коли потрібно за допомогою умов обмежити діапазон даних, до якого застосовується функція. Наприклад, щоб відобразити стандартне відхилення для замовлень, які мають доставлятися до Каліфорнії, установіть властивість ControlSource текстового поля для такого виразу:
=DStDev("[Freight]", "Orders", "[ShipRegion] = 'CA'")
Якщо потрібно просто знайти стандартне відхилення для всіх записів в аргументі domain, скористайтеся функцією StDev або StDevP.
Порада Якщо поле, з якого визначається аргумент expr, має числовий тип даних, то функції DStDev і DStDevP повертають значення з типом даних Double. Якщо функція DStDev або DStDevP використовується в обчислюваному елементі керування, додайте до виразу функцію перетворення типів даних, щоб підвищити продуктивність.
Примітка.: Незбережені зміни в записах у домені не включаються під час використання цих функцій. Якщо потрібно, щоб функція DStDev або DStDevP базвалася на змінених значеннях, спочатку потрібно зберегти зміни, натиснувши кнопку Зберегти запис у розділі Записи на вкладці Дані , перемістити фокус до іншого запису або скористатися методом Оновлення .
Приклади запитів
Вираз |
Результати |
SELECT DStDev("ціна за одиницю";"продаж товару";"ціна за одиницю>140") AS вираз1, DStDevP("ціна_за_одиницю";"продаж товару";"ціна_за_одиницю<140") AS Вираз2 ВІД продуктуПродаж GROUP ЗА DStDev("ціна за одиницю товару","продаж товару";"ціна за одиницю>140"), DStDevP("вартість одиниці товару","продаж товару";"вартість одиниці товару<140"); |
Обчислює стандартне відхилення "Ціна за одиницю" (враховуючи te given data as sample) з таблиці "Продажі товару", де "ціна за одиницю" перевищує 140, і відображає результат у виразі 1. Також обчислює стандартне відхилення "Ціна за одиницю" (враховуючи дані як генеральну сукупність), де "ціна за одиницю" менша за 140 і відображає результати в виразі 2. |
SELECT DStDev("unitprice","productSales","ціна за одиницю>140") AS DstDev, DStDevP("ціна_за_одиницю";"продаж товару","ціна за одиницю<140") AS DstDevP FROM PRODUCTSales GROUP BY DStDev("ціна за одиницю";"продаж товару";"ціна за одиницю>140"), DStDevP("вартість одиниці товару","продаж товару";"вартість одиниці товару<140"); |
Обчислює стандартне відхилення "Ціна за одиницю" (з урахуванням te given data as sample) з таблиці "Продажі товару", де "ціна за одиницю" перевищує 140, і відображає результат у DstDev. Також обчислює стандартне відхилення "Ціна за одиницю" (враховуючи дані як генеральну сукупність), де "ціна за одиницю" менша за 140 і відображає результати в DstDevP. |
Приклад VBA
Примітка.: У прикладах нижче показано використання цієї функції в модулі Visual Basic for Applications (VBA). Щоб отримати докладні відомості про використання модуля VBA, клацніть пункт Довідник розробника в розкривному списку поряд із полем Пошук і введіть у поле пошуку принаймні один термін.
У наведеному нижче прикладі повертаються оцінки стандартного відхилення для сукупності й вибірки із сукупності для замовлень, доставлених до Сполученого Королівства. Домен – це таблиця "Замовлення". Аргумент criteria обмежує отриманий набір записів, включаючи в нього лише ті, у яких поле "ShipCountryRegion" має значення "UK".
Dim dblX As Double
Dim dblY As Double ' Sample estimate. dblX = DStDev("[Freight]", "Orders", _ "[ShipCountryRegion] = 'UK'") ' Population estimate. dblY = DStDevP("[Freight]", "Orders", _ "[ShipCountryRegion] = 'UK'")
У наступному прикладі обчислюються ті самі оцінки, використовуючи змінну, strCountryRegion, в аргументі умови . Зверніть увагу, що в рядковий вираз включено одинарні лапки ('), тому, коли рядки об'єднуються, рядок-літерал UK братиметься в одинарні лапки.
Dim strCountryRegion As String
Dim dblX As Double Dim dblY As Double strCountryRegion = "UK" dblX = DStDev("[Freight]", "Orders", _ "[ShipCountryRegion] = '" & strCountryRegion & "'") dblY = DStDevP("[Freight]", "Orders", _ "[ShipCountryRegion] = '" & strCountryRegion & "'")