Applies ToAccess pre Microsoft 365 Access 2024 Access 2021 Access 2019 Access 2016

Funkciu Nz môžete použiť na vrátenie nuly, reťazec nulovej dĺžky (" ) alebo inej zadanej hodnoty, ak má variant hodnotu Null. Túto funkciu môžete použiť napríklad na skonvertovanie hodnoty Null na inú hodnotu a zabránenie jej rozšíreniu prostredníctvom výrazu.

Syntax

Nz ( variant [, valueifnull ] )

Syntax funkcie Nz má tieto argumenty:

Argument

Popis

variant

Povinné. Premenná pre typ údajov Variant.

valueifnull

Voliteľné (ak sa nepoužíva v dotaze). Typ údajov Variant poskytujúci hodnotu, ktorá sa má vrátiť, ak má argument variant hodnotu null. Tento argument umožňuje vrátiť hodnotu inú ako nula alebo reťazec s nulovou dĺžkou.

Poznámka: Ak použijete funkciu Nz vo výraze v dotaze bez použitia argumentu valueifnull, výsledkom bude reťazec s nulovou dĺžkou v poliach, ktoré obsahujú hodnoty null.

Ak je hodnota argumentu variantNull, funkcia Nz vráti číslo nula alebo reťazec s nulovou dĺžkou (reťazec s nulovou dĺžkou vráti vždy vtedy, keď sa použije vo výraze dotazu) podľa toho, či z kontextu vyplýva, že hodnota by mala byť číslo alebo reťazec. Ak je súčasťou funkcie voliteľný argument valueifnull, funkcia Nz vráti hodnotu zadanú argumentom v prípade, že argument variant má hodnotu null. Ak sa funkcia NZ použije vo výraze dotazu, vždy by mala zahŕňať argument valueifnull.

Ak hodnota argumentu variant nie je Null, funkcia Nz vráti hodnotu argumentu variant.

Poznámky

Funkcia Nz je užitočná pre výrazy, ktoré môžu zahŕňať hodnoty Null. Ak chcete donútiť výraz k tomu, aby sa vyhodnotil ako hodnota iná než Null aj vtedy, keď obsahuje hodnotu Null, použite na vrátenie nuly, reťazca s nulovou dĺžkou alebo vlastnej vrátenej hodnoty funkciu Nz.

Napríklad výraz 2 + varX vždy vráti hodnotu Null, keď je Variant varXNull. 2 + Nz(varX) však vráti hodnotu 2.

Funkciu Nz je často možné použiť ako alternatívu k funkcii IIf. Napríklad na vrátenie požadovaného výsledku sú v nasledujúcom kóde potrebné dva výrazy obsahujúce funkciu IIf. Prvý výraz obsahujúci funkciu IIf sa použije na kontrolu hodnoty premennej a ak je hodnota Null, tak aj na jej konvertovanie na nulu.

varTemp = IIf(IsNull(varFreight), 0, varFreight)varResult = IIf(varTemp > 50, "High", "Low")

V nasledujúcom príklade funguje funkcia Nz rovnako ako prvý výraz a na dosiahnutie požadovaného výsledku stačí jeden, nie dva kroky.

varResult = IIf(Nz(varFreight) > 50, "High", "Low")

Po zadaní hodnoty pre voliteľný argument valueifnull sa v prípade, že argument variant má hodnotu Null, daná hodnota vráti. Pri použití voliteľného argumentu je možné vyhnúť sa použitiu výrazu obsahujúceho funkciu IIf. Nasledujúci výraz napríklad použije na vrátenie reťazca funkciu IIf v prípade, že je hodnota argumentu varFreightNull.

varResult = IIf(IsNull(varFreight), _    "No Freight Charge", varFreight)

V nasledujúcom príklade voliteľný argument zadaný funkcii Nz poskytne reťazec, ktorý sa má vrátiť, ak je hodnota argumentu varFreightNull.

varResult = Nz(varFreight, "No Freight Charge")

Príklady dotazu

Výraz

Výsledky

SELECT ProductID, NZ(Discount;"No Detail Available") AS Expr2 FROM ProductSales;

Vráti hodnotu ProductID v stĺpci Expr1, vyhodnotí hodnoty Null v poli Zľava a vráti hodnotu "Nie sú k dispozícii žiadne podrobnosti" pre všetky hodnoty Null (vráti hodnoty iné ako null tak, ako sú).

SELECT ProductID, NZ(Discount;"No Detail Available") AS ReplaceNull FROM ProductSales;

Vráti hodnotu ProductID v stĺpci Produkt, vyhodnotí hodnoty Null v poli Zľava a vráti hodnotu "Nie sú k dispozícii žiadne podrobnosti" pre všetky hodnoty Null (vráti hodnoty bez hodnoty null tak, ako sú) a zobrazí sa v stĺpci ReplaceNull.

Príklad jazyka VBA

Poznámka: Nasledujúce príklady ukazujú použitie tejto funkcie v module jazyka Visual Basic for Applications (VBA). Ak chcete získať ďalšie informácie o práci s jazykom VBA, vyberte z rozbaľovacieho zoznamu vedľa položky Hľadať možnosť Odkaz pre vývojára a do vyhľadávacieho poľa zadajte nejaké výrazy.

Nasledujúci príklad vyhodnotí ovládací prvok vo formulári a na základe hodnoty ovládacieho prvku vráti jeden z dvoch reťazcov. Ak je hodnota ovládacieho prvku Null, v postupe sa použije funkcia Nz, ktorá skonvertuje hodnotu Null na reťazec s nulovou dĺžkou.

Public Sub CheckValue()    Dim frm As Form    Dim ctl As Control    Dim varResult As Variant    ' Return Form object variable     ' pointing to Orders form.    Set frm = Forms!Orders    ' Return Control object variable     ' pointing to ShipRegion.    Set ctl = frm!ShipRegion    ' Choose result based on value of control.    varResult = IIf(Nz(ctl.Value) = vbNullString, _        "No value.", "Value is " & ctl.Value & ".")    ' Display result.    MsgBox varResult, vbExclamationEnd Sub

Potrebujete ďalšiu pomoc?

Chcete ďalšie možnosti?

Môžete preskúmať výhody predplatného, prehľadávať školiace kurzy, naučiť sa zabezpečiť svoje zariadenie a ešte oveľa viac.

Komunity pomôžu s kladením otázok a odpovedaním na ne, s poskytovaním pripomienok a so získavaním informácií od odborníkov s bohatými znalosťami.