Hledání posledních záznamů před daným časem – MS SQL – Fórum – Programujte.com
 x   TIP: Přetáhni ikonu na hlavní panel pro připnutí webu

Hledání posledních záznamů před daným časem – MS SQL – Fórum – Programujte.comHledání posledních záznamů před daným časem – MS SQL – Fórum – Programujte.com

 

Moll
~ Anonymní uživatel
3 příspěvky
9. 5. 2018   #1
-
0
-

Potřebuji najít posledních záznamy pro osoby (pro každou jeden) před danným časem. Pro jednu je to snadné:

SELECT * FROM TABLE WHERE person="osoba" AND event_time<"2017-09-01 01:40:07" ORDER BY event_time DESC LIMIT 1;

Potřebuji to ale pro více osob, které si můžu zadat třeba seznamem do IN:

SELECT * FROM dat_communications WHERE PHYSICAL IN ("X", "Y", "Z")

Při použití GROUP BY a pod narážím pořád na nějaké problémy. Lze to nějak zkombinovat? Nebo v proceduře sestavit select pomocí UNION?

Dík za radu!

Nahlásit jako SPAM
IP: 31.31.226.–
gna
~ Anonymní uživatel
1891 příspěvků
9. 5. 2018   #2
-
0
-

Při použití group by musíš v selectu říct, kterou hodnotu ze skupin vybrat. 

SELECT osoba, 
       Max(datum) AS datum 
FROM   tabulka 
WHERE  osoba IN ( ... ) 
       AND datum < ... 
GROUP  BY osoba
;
Nahlásit jako SPAM
IP: 213.211.51.–
Moll
~ Anonymní uživatel
3 příspěvky
10. 5. 2018   #3
-
0
-

#2 gna
Tohle

SELECT osoba, datum,
       Max(datum) AS MaxDatum 
FROM   tabulka 
WHERE  osoba IN ( ... ) 
       AND datum < ... 
GROUP  BY osoba

vede k výsledku např.:

60758     2013-10-23 14:11:58   2018-03-02 14:33:15

kde všechny ostatní sloupce se vztahují k tomu datu 2013-10-23 14:11:58 (ne maximální, ale první) - které mne ale vůbec nezajímá. Samozřejmě, že mi jde o ty ostatní sloupce a osoba + datum nejsou klíč

To jsou ty problémy, které jsem zmínil.

Nahlásit jako SPAM
IP: 31.31.226.–
gna
~ Anonymní uživatel
1891 příspěvků
11. 5. 2018   #4
-
0
-

1. To jsem tušil a myslím si, že jsem dost jasně napsal, že při sekupování musíš určit, kterou hodnotu chceš vybrat.

2. Taky si myslím, že bez toho to v MS SQL ani nejde, takže teď předpokládám MySQL.

3. Když se to pokušíš použít, jak jsem to napsal, tak nějak logicky.

SELECT * 
FROM   tabulka 
WHERE  ( osoba, datum ) IN (SELECT osoba, Max(datum) 
                            FROM   tabulka 
                            GROUP  BY osoba);
Nahlásit jako SPAM
IP: 213.211.51.–
Moll
~ Anonymní uživatel
3 příspěvky
11. 5. 2018   #5
-
0
-

Psal jsem i že osoba, datum nestačí na klíč, ale umím zařídit aby bylo a je to pod desetinu s, takže mi to stačí, dík.
 

Nahlásit jako SPAM
IP: 31.31.226.–
Zjistit počet nových příspěvků

Přidej příspěvek

Toto téma je starší jak čtvrt roku – přidej svůj příspěvek jen tehdy, máš-li k tématu opravdu co říct!

Ano, opravdu chci reagovat → zobrazí formulář pro přidání příspěvku

×Vložení zdrojáku

×Vložení obrázku

Vložit URL obrázku Vybrat obrázek na disku
Vlož URL adresu obrázku:
Klikni a vyber obrázek z počítače:

×Vložení videa

Aktuálně jsou podporována videa ze serverů YouTube, Vimeo a Dailymotion.
×
 
Podporujeme Gravatara.
Zadej URL adresu Avatara (40 x 40 px) nebo emailovou adresu pro použití Gravatara.
Email nikam neukládáme, po získání Gravatara je zahozen.
-
Pravidla pro psaní příspěvků, používej diakritiku. ENTER pro nový odstavec, SHIFT + ENTER pro nový řádek.
Sledovat nové příspěvky (pouze pro přihlášené)
Sleduj vlákno a v případě přidání nového příspěvku o tom budeš vědět mezi prvními.
Reaguješ na příspěvek:

Uživatelé prohlížející si toto vlákno

Uživatelé on-line: 0 registrovaných, 3 hosté

 

Hostujeme u Českého hostingu       ISSN 1801-1586       ⇡ Nahoru Webtea.cz logo © 20032024 Programujte.com
Zasadilo a pěstuje Webtea.cz, šéfredaktor Lukáš Churý