Toon posts:

Mysql, if column a is not null, column b is not null. hoe?

Pagina: 1
Acties:

Vraag


  • AlphaJuno2
  • Registratie: September 2012
  • Laatst online: 01-02 11:33
Ik moet een gegevens uit onderstaande tabel halen.
In dit geval wil ik id 2 en id 3 selecteren en id 1 skippen
Dus wanneer column document NULL is, moet column date ook NULL zijn, heeft column document een waarde, dan moet column date ook een waarde hebben.

+----+------+----------+------------+
| id | name | document |    date    |
+----+------+----------+------------+
| 1  | John |  doc01   |    NULL    |
| 2  | Jane |  NULL    |    NULL    |
| 3  | Mark |  doc02   | 23-10-2018 |
+----+------+----------+------------+


Iemand een idee hoe deze query er uit komt te zien?

Alvast bedankt

Beste antwoord (via AlphaJuno2 op 23-10-2018 12:04)


  • Harrie_
  • Registratie: Juli 2003
  • Niet online

Harrie_

⠀                  🔴 🔴 🔴 🔴 🔴

SQL:
1
2
3
4
5
6
7
8
9
10
SELECT
      id
    , name
    , document
    , date
FROM table
WHERE
    (document IS NOT NULL AND date IS NOT NULL)
    OR
    (document IS NULL AND date IS NULL)
MichielPH schreef op dinsdag 23 oktober 2018 @ 11:43:
Er valt ook iets voor te zeggen om het op te splitsen in 2 tabellen:
Dan kan je documentId en date nullable maken.
We kennen de usecase niet? Misschien is het een bestaande tabel waar TS data uit wil halen?

[Voor 45% gewijzigd door Harrie_ op 23-10-2018 11:45]

☀️ 18 Panelen | 🔋 5,8 kWp | ⚡ SolarEdge SE6K

Alle reacties


  • Mavamaarten
  • Registratie: September 2009
  • Laatst online: 20:22

Mavamaarten

Omdat het kan!

Pseudocode:
if((document == null AND date == null) OR (document != null AND date != null))

Daar moet je het wel mee kunnen doen?

Android developer & dürüm-liefhebber


  • MichielPH
  • Registratie: Februari 2005
  • Laatst online: 21-01 16:03
Er valt ook iets voor te zeggen om het op te splitsen in 2 tabellen:

+----+------+-------------+
| id | name | documentId  |
+----+------+-------------+
| 1  | John |      1      |
| 2  | Jane |     NULL    |
| 3  | Mark |      2      |
+----+------+-------------+


+----+-------+------------+
| id | name |    date     |
+----+-------+------------+
| 1  | doc01 |  NULL      |
| 1  | doc02 | 23-10-2018 |
+----+-------+------------+


Dan kan je documentId en date nullable maken.

edit:
Vraag niet goed begrepen, tijd voor koffie.

[Voor 4% gewijzigd door MichielPH op 23-10-2018 11:44]


Acties:
  • Beste antwoord
  • +1Henk 'm!

  • Harrie_
  • Registratie: Juli 2003
  • Niet online

Harrie_

⠀                  🔴 🔴 🔴 🔴 🔴

SQL:
1
2
3
4
5
6
7
8
9
10
SELECT
      id
    , name
    , document
    , date
FROM table
WHERE
    (document IS NOT NULL AND date IS NOT NULL)
    OR
    (document IS NULL AND date IS NULL)
MichielPH schreef op dinsdag 23 oktober 2018 @ 11:43:
Er valt ook iets voor te zeggen om het op te splitsen in 2 tabellen:
Dan kan je documentId en date nullable maken.
We kennen de usecase niet? Misschien is het een bestaande tabel waar TS data uit wil halen?

[Voor 45% gewijzigd door Harrie_ op 23-10-2018 11:45]

☀️ 18 Panelen | 🔋 5,8 kWp | ⚡ SolarEdge SE6K


  • RobIII
  • Registratie: December 2001
  • Laatst online: 01:55

RobIII

Admin Devschuur®

^ Romeinse Ⅲ ja!

Komaan zeg. Leg dan op z'n minst uit hoe je met die query op de proppen kwam en/of geef wat onderbouwing...
Give a man a fish and feed him for a day. Teach a man how to fish and feed him for a lifetime.
Laten we nou eens kappen met kant-en-klare oplossingen neer te zetten. Niemand heeft er baat bij als we van de Devschuur® een afhaalchinees of slap Stackoverflow aftreksel maken.

[Voor 4% gewijzigd door RobIII op 23-10-2018 11:52]

There are only two hard problems in distributed systems: 2. Exactly-once delivery 1. Guaranteed order of messages 2. Exactly-once delivery.

Roses are red Violets are blue, Unexpected ‘{‘ on line 32.

Over mij


  • AlphaJuno2
  • Registratie: September 2012
  • Laatst online: 01-02 11:33
SQL:
1
2
3
4
5
6
7
8
9
10
SELECT
      id
    , name
    , document
    , date
FROM table
WHERE
    (document IS NOT NULL AND date IS NOT NULL)
    OR
    (document IS NULL AND date IS NULL)
Super bedankt voor je antwoord. ;)

Totaal niet bij stil gestaan dat ik ook een OR operator kan gebruiken.
Pagina: 1


Tweakers maakt gebruik van cookies

Tweakers plaatst functionele en analytische cookies voor het functioneren van de website en het verbeteren van de website-ervaring. Deze cookies zijn noodzakelijk. Om op Tweakers relevantere advertenties te tonen en om ingesloten content van derden te tonen (bijvoorbeeld video's), vragen we je toestemming. Via ingesloten content kunnen derde partijen diensten leveren en verbeteren, bezoekersstatistieken bijhouden, gepersonaliseerde content tonen, gerichte advertenties tonen en gebruikersprofielen opbouwen. Hiervoor worden apparaatgegevens, IP-adres, geolocatie en surfgedrag vastgelegd.

Meer informatie vind je in ons cookiebeleid.

Sluiten

Toestemming beheren

Hieronder kun je per doeleinde of partij toestemming geven of intrekken. Meer informatie vind je in ons cookiebeleid.

Functioneel en analytisch

Deze cookies zijn noodzakelijk voor het functioneren van de website en het verbeteren van de website-ervaring. Klik op het informatie-icoon voor meer informatie. Meer details

janee

    Relevantere advertenties

    Dit beperkt het aantal keer dat dezelfde advertentie getoond wordt (frequency capping) en maakt het mogelijk om binnen Tweakers contextuele advertenties te tonen op basis van pagina's die je hebt bezocht. Meer details

    Tweakers genereert een willekeurige unieke code als identifier. Deze data wordt niet gedeeld met adverteerders of andere derde partijen en je kunt niet buiten Tweakers gevolgd worden. Indien je bent ingelogd, wordt deze identifier gekoppeld aan je account. Indien je niet bent ingelogd, wordt deze identifier gekoppeld aan je sessie die maximaal 4 maanden actief blijft. Je kunt deze toestemming te allen tijde intrekken.

    Ingesloten content van derden

    Deze cookies kunnen door derde partijen geplaatst worden via ingesloten content. Klik op het informatie-icoon voor meer informatie over de verwerkingsdoeleinden. Meer details

    janee