Tipy pro MS Access - práce s dotazy

1. 2. 1999

Sdílet

Výběr pouze určitého počtu záznamů- K zobrazení určitého počtu záznamů s nejvyšší či nejnižší hodnotou jako příklad můžeme uvést seznam 20 prodejců s nejvyšší provizí p...
Výběr pouze určitého počtu záznamů
- K zobrazení určitého počtu záznamů s nejvyšší či nejnižší hodnotou jako
příklad můžeme uvést seznam 20 prodejců s nejvyšší provizí použijte následující
postup: V návrhovém zobrazení zvolte pole, která mají být zobrazena (např.
příjmení prodejce a provize), dále zvolte Řadit sestupně podle pole provize, a
v okně Vlastnosti dotazu zadejte hodnotu 20 v poli Nejvyšší hodnoty (v tomto
poli můžete zadat i údaj v procentech, např. 5 %).
- Pokud chcete, aby uživatel při spuštění dotazu k výběru záznamů měl možnost
zvolit parametr, třeba příjmení prodejce, použijte tento postup: V návrhové
mřížce dotazu v políčku Kritéria u pole prijmeni zapište text (v hranatých
závorkách [Zadejte jméno prodejce:]), který se zobrazí v dialogovém okně pro
zadání parametru před vlastním provedením dotazu (viz obr. 1).
- Access dovoluje vnořovat dotazy SELECT; např. ke zjištění prodejců, kteří
vyhovují podmínkám jiného dotazu (Dotaz2), můžete použít klíčové slovo EXISTS

SELECT prijmeni, skupina FROM Prodejci WHERE EXISTS
SELECT * FROM dotaz2 WHERE Prodejci.Prijmeni=Prijmeni);

Použití dotazů v programovém kódu
- Dotaz uložený v databázi (např. qryProdejci) můžete spustit v programu
příkazem DoCmd.OpenQuery "qryProdejci" nebo dotaz přímo zapište DoCmd.RunSQL
"DELETE * FROM prodejci WHERE obrat prodejci WHERE obrat>0 ORDER BY obrat DESC" (kde Dbs je proměnná typu Database).
- Nechcete-li, aby se před provedením dotazu objevilo okno s upozorněním a
nutností následného potvrzení (viz obr. 2), použijte metodu SetWarnings příkazu
DoCmd. Probíhá-li dotaz delší dobu, použijte k zobrazení hodin metodu
Hourglass. Ukázka použití by mohla vypadat takto:

DoCmd.Hourglass True
DoCmd. SetWarningsFalse
...
DoCmd.OpenQuery"qryProdejci"
...
DoCmd.Set WarningsTrue
DoCmd. Hourglass False

- Chcete-li otevřít množinu záznamů na základě dotazu, můžete použít metodu
OpenRecordset a jako parametr zadat dotaz SQL; např.:

Dim dbs As DATABASE, rst As Recordset, dotaz As
String
Set dbs = CurrentDb
dotaz = "SELECT * FROM Smlouvy WHERE ([Vysledek] =
\storno\)"
Set rst = dbs.OpenRecordset(dotaz)

- Při použití dotazu, který obsahuje údaj typu datum, musíte tento údaj zapsat
ve formátu používaném v USA (tedy mm/dd/yy). Špatně je tedy příkaz SELECT *
FROM prodejci WHERE ([Datum_nar] >= # 11.1.1968#), správně pak příkaz
([Datum_nar] >= #1/11/1968#\). Pokud v dotazu používáte proměnnou, velmi
užitečné je k převodu formátu datumu použít funkci Format.

Křížové dotazy
- Nejjednodušší způsob, jak vytvořit křížový dotaz, je použití průvodce (v okně
Nový dotaz zvolíte Průvodce křížovým dotazem). V jednotlivých krocích zvolíte
potřebné parametry; definici dotazu můžete samozřejmě dodatečně pozměnit v
návrhovém zobrazení nebo přímo kódu SQL (Access obsahuje příkaz TRANSFORM navíc
oproti normě ANSI SQL).

Agregační funkce
- Velmi užitečné při používání dotazů jsou agregační funkce Avg, Count, Min,
Max, Sum a statistické funkce pro směrodatnou odchylku a rozptyl StDev a Var (a
jejich odhady StDevP a VarP). Při použití těchto funkcí však nelze použít
klauzuli DISTINCT, např. SELECT COUNT(DISTINCT id_prodejce) FROM prodeje pro
zjištění počtu prodejců, kteří uskutečnili alespoň jeden obchod.
- Zadáte-li jako parametr agregační funkce Count název určitého pole (např.
Count([jmeno])), budou do součtu zahrnuty pouze záznamy, jejichž pole jmeno
není prázdné (tedy neobsahuje hodnotu NULL). Chcete-li zjistit počet všech
záznamů, použijte Count(*). Počet všech záznamů s neprázdnými hodnotami v
polích jmeno a prijmeni zároveň pak zjistíte funkcí Count([jmeno]&([prijmeni]).
- Na rozdíl od funkce Count funkce Sum (např. Sum([plat])) do výsledného součtu
zahrne i záznamy s hodnotou NULL.
- Funkce na výpočet aritmetického průměru Avg do výpočtu nezahrne hodnoty NULL.
Při výpočtu průměrného věku obchodních partnerů je použití Avg([vek] v pořádku,
neboť partneři s neznámým stářím prázdnou hodnotou v poli vek nejsou do výpočtu
zahrnuti. Chybou však je výpočet průměrného počtu objednávek prodejců, kdy
hodnota NULL "reprezentuje" nulový počet objednávek. V tomto případě použijte
funkci Nz; tedy místo Avg([poc_obj]) použijte Avg(Nz([poc_obj])).

Další
- Přidáváte-li záznamy do tabulky, která obsahuje pole typu Automatické číslo,
budou přidané záznamy číslovány od nejvyšší hodnoty zvětšené o jednu tohoto
pole v cílové tabulce (pokud jste ovšem předtím nesmazali záznamy v cílové
tabulce s nejvyššími hodnotami bez provedení následné komprimace).
- Ke zjištění záznamů, jež existují v jedné tabulce a nejsou v tabulce druhé;
např. prodejci, kteří neuzavřeli ani jednu objednávku (tabulky Prodejci a
Objednavky, vazba přes pole ID_prodejce), použijte buď Průvodce vyhledávacím
dotazem (chybějící záznamy), nebo v návrhovém zobrazení vytvořte dotaz (u pole
smlouvy.ID_Prodejce zadejte Zobrazit Ne, Kritéria Null). Jiná možnost je v
zobrazení SQL přímo zapsat příkaz SELECT prodejci.* FROM prodejci LEFT JOIN
objednavky ON Prodejci.ID_Prodejce = Smlouvy.ID_Prodejce WHERE ((smlouvy.
ID_Prodejce IS NULL)).
- Chcete-li zobrazit tzv. vypočítávané pole, např. cenu s DPH, a v tabulce máte
cenu bez DPH (pole Cena), zadejte v mřížce návrhu do políčka Pole text Cena s
DPH: [Cena]*1,22. Text Cena s DPH pak tvoří název vypočítávaného pole.

9 0047/OK
'; document.getElementById('preroll-iframe').onload = function () { setupIframe(); } prerollContainer = document.getElementsByClassName('preroll-container-iframe')[0]; } function setupIframe() { prerollDocument = document.getElementById('preroll-iframe').contentWindow.document; let el = prerollDocument.createElement('style'); prerollDocument.head.appendChild(el); el.innerText = "#adContainer>div:nth-of-type(1),#adContainer>div:nth-of-type(1) > iframe { width: 99% !important;height: 99% !important;max-width: 100%;}#videoContent,body{ width:100vw;height:100vh}body{ font-family:'Helvetica Neue',Arial,sans-serif}#videoContent{ overflow:hidden;background:#000}#adMuteBtn{ width:35px;height:35px;border:0;background:0 0;display:none;position:absolute;fill:rgba(230,230,230,1);bottom:20px;right:25px}"; videoContent = prerollDocument.getElementById('contentElement'); videoContent.style.display = 'none'; videoContent.volume = 1; videoContent.muted = false; const playPromise = videoContent.play(); if (playPromise !== undefined) { playPromise.then(function () { console.log('PREROLL sound allowed'); // setUpIMA(true); videoContent.volume = 1; videoContent.muted = false; setUpIMA(); }).catch(function () { console.log('PREROLL sound forbidden'); videoContent.volume = 0; videoContent.muted = true; setUpIMA(); }); } } function setupDimensions() { prerollWidth = Math.min(iinfoPrerollPosition.offsetWidth, 480); prerollHeight = Math.min(iinfoPrerollPosition.offsetHeight, 320); } function setUpIMA() { google.ima.settings.setDisableCustomPlaybackForIOS10Plus(true); google.ima.settings.setLocale('cs'); google.ima.settings.setNumRedirects(10); // Create the ad display container. createAdDisplayContainer(); // Create ads loader. adsLoader = new google.ima.AdsLoader(adDisplayContainer); // Listen and respond to ads loaded and error events. adsLoader.addEventListener( google.ima.AdsManagerLoadedEvent.Type.ADS_MANAGER_LOADED, onAdsManagerLoaded, false); adsLoader.addEventListener( google.ima.AdErrorEvent.Type.AD_ERROR, onAdError, false); // An event listener to tell the SDK that our content video // is completed so the SDK can play any post-roll ads. const contentEndedListener = function () { adsLoader.contentComplete(); }; videoContent.onended = contentEndedListener; // Request video ads. const adsRequest = new google.ima.AdsRequest(); adsRequest.adTagUrl = iinfoVastUrls[iinfoVastUrlIndex]; console.log('Preroll advert: ' + iinfoVastUrls[iinfoVastUrlIndex]); videoContent.muted = false; videoContent.volume = 1; // Specify the linear and nonlinear slot sizes. This helps the SDK to // select the correct creative if multiple are returned. // adsRequest.linearAdSlotWidth = prerollWidth; // adsRequest.linearAdSlotHeight = prerollHeight; adsRequest.nonLinearAdSlotWidth = 0; adsRequest.nonLinearAdSlotHeight = 0; adsLoader.requestAds(adsRequest); } function createAdDisplayContainer() { // We assume the adContainer is the DOM id of the element that will house // the ads. prerollDocument.getElementById('videoContent').style.display = 'none'; adDisplayContainer = new google.ima.AdDisplayContainer( prerollDocument.getElementById('adContainer'), videoContent); } function unmutePrerollAdvert() { adVolume = !adVolume; if (adVolume) { adsManager.setVolume(0.3); prerollDocument.getElementById('adMuteBtn').innerHTML = ''; } else { adsManager.setVolume(0); prerollDocument.getElementById('adMuteBtn').innerHTML = ''; } } function onAdsManagerLoaded(adsManagerLoadedEvent) { // Get the ads manager. const adsRenderingSettings = new google.ima.AdsRenderingSettings(); adsRenderingSettings.restoreCustomPlaybackStateOnAdBreakComplete = true; adsRenderingSettings.loadVideoTimeout = 12000; // videoContent should be set to the content video element. adsManager = adsManagerLoadedEvent.getAdsManager(videoContent, adsRenderingSettings); // Add listeners to the required events. adsManager.addEventListener(google.ima.AdErrorEvent.Type.AD_ERROR, onAdError); adsManager.addEventListener( google.ima.AdEvent.Type.CONTENT_PAUSE_REQUESTED, onContentPauseRequested); adsManager.addEventListener( google.ima.AdEvent.Type.CONTENT_RESUME_REQUESTED, onContentResumeRequested); adsManager.addEventListener( google.ima.AdEvent.Type.ALL_ADS_COMPLETED, onAdEvent); // Listen to any additional events, if necessary. adsManager.addEventListener(google.ima.AdEvent.Type.LOADED, onAdEvent); adsManager.addEventListener(google.ima.AdEvent.Type.STARTED, onAdEvent); adsManager.addEventListener(google.ima.AdEvent.Type.COMPLETE, onAdEvent); playAds(); } function playAds() { // Initialize the container. Must be done through a user action on mobile // devices. videoContent.load(); adDisplayContainer.initialize(); // setupDimensions(); try { // Initialize the ads manager. Ad rules playlist will start at this time. adsManager.init(1920, 1080, google.ima.ViewMode.NORMAL); // Call play to start showing the ad. Single video and overlay ads will // start at this time; the call will be ignored for ad rules. adsManager.start(); // window.addEventListener('resize', function (event) { // if (adsManager) { // setupDimensions(); // adsManager.resize(prerollWidth, prerollHeight, google.ima.ViewMode.NORMAL); // } // }); } catch (adError) { // An error may be thrown if there was a problem with the VAST response. // videoContent.play(); } } function onAdEvent(adEvent) { const ad = adEvent.getAd(); console.log('Preroll event: ' + adEvent.type); switch (adEvent.type) { case google.ima.AdEvent.Type.LOADED: if (!ad.isLinear()) { videoContent.play(); } prerollDocument.getElementById('adContainer').style.width = '100%'; prerollDocument.getElementById('adContainer').style.maxWidth = '640px'; prerollDocument.getElementById('adContainer').style.height = '360px'; break; case google.ima.AdEvent.Type.STARTED: window.addEventListener('scroll', onActiveView); if (ad.isLinear()) { intervalTimer = setInterval( function () { // Example: const remainingTime = adsManager.getRemainingTime(); // adsManager.pause(); }, 300); // every 300ms } prerollDocument.getElementById('adMuteBtn').style.display = 'block'; break; case google.ima.AdEvent.Type.ALL_ADS_COMPLETED: if (ad.isLinear()) { clearInterval(intervalTimer); } if (prerollLastError === 303) { playYtVideo(); } break; case google.ima.AdEvent.Type.COMPLETE: if (ad.isLinear()) { clearInterval(intervalTimer); } playYtVideo(); break; } } function onAdError(adErrorEvent) { console.log(adErrorEvent.getError()); prerollLastError = adErrorEvent.getError().getErrorCode(); if (!loadNext()) { playYtVideo(); } } function loadNext() { iinfoVastUrlIndex++; if (iinfoVastUrlIndex < iinfoVastUrls.length) { iinfoPrerollPosition.remove(); playPrerollAd(); } else { return false; } adVolume = 1; return true; } function onContentPauseRequested() { videoContent.pause(); } function onContentResumeRequested() { videoContent.play(); } function onActiveView() { if (prerollContainer) { const containerOffset = prerollContainer.getBoundingClientRect(); const windowHeight = window.innerHeight; if (containerOffset.top < windowHeight/1 && containerOffset.bottom > 0.0) { if (prerollPaused) { adsManager.resume(); prerollPaused = false; } return true; } else { if (!prerollPaused) { adsManager.pause(); prerollPaused = true; } } } return false; } function playYtVideo() { iinfoPrerollPosition.remove(); youtubeIframe.style.display = 'block'; youtubeIframe.src += '&autoplay=1&mute=1'; } }