zwangseinweisung
Goto Top

SQL-Abfrage und leere Felder vermeiden

Hallo,

ich mache grade eine Ausbildung zum Fi-Si und vor dem Weihnachtsurlaub haben wir im Fach Datenbanken noch eine Aufgabe bekommen die wir lösen sollen. Nun renn ich aber die ganze Zeit mit dem Kopf vor die Wand und finde keine Lösung. Aufgabe ist: Wir haben eine Tabelle in der Vor und Nachnamen stehen. Jetzt sollen wir zufällige Namen generieren lassen aber die Spalten sind ungleichmäßig. Es sind mehr Vor als Nachname in der Tabelle. Wenn ich jetzt eine abfrage mache:

Select * from names ORDER by RAND() LIMIT 200;

kommt dann sowas z.b. raus:

Ortfried Göring
Holle Mittelstädt
Gundela Mair
Wald
Annelene Johannsen
Eva-Maria Lackner
Volkhardt Henschel
Mathias Geißler
Weck
Wrede
Hannelore März
Sighilde Schreiner

Wie verhindere ich das sowas passiert wie Wald, Weck oder Wrede?

vielen, lieben dank

Content-ID: 324849

Url: https://administrator.de/contentid/324849

Ausgedruckt am: 22.11.2024 um 18:11 Uhr

131381
131381 25.12.2016 aktualisiert um 18:50:21 Uhr
Goto Top
Mit where ?
Select * from names WHERE Vorname IS NOT NULL AND Nachname IS NOT NULL ORDER by RAND() LIMIT 200;
Gruß mik

zwangseinweisung
War dein Weihnachten echt so schlimm face-smile?
wiesi200
wiesi200 25.12.2016 um 18:45:22 Uhr
Goto Top
Hallo,

was hast du denn schon versucht?

Vor- und Nachnamen hast du ja sicher in separaten Spalten.

Wie wär noch die Bedingung "Vorname is not Null or Nachname is not Null"

Wie das dann genau aussehen musst kannst du selber versuchen zusammen zu setzten.
zwangseinweisung
zwangseinweisung 25.12.2016 um 19:04:46 Uhr
Goto Top
Grummel, irgendwo drauf geklickt und jetzt ists als "gelöst" markiert.

Die Tabelle sieht so aus:

+----------------------------+
| Vorname      | Nachname    |
+--------------+-------------+
| Alex         | Sagichnicht |
| Bernd        | Geheim      |
|              | Nope        |
+--------------+-------------+

Mit dem

Select * from names WHERE Vorname IS NOT NULL AND Nachname IS NOT NULL ORDER by RAND() LIMIT 200;

von oben habe ich das selbe Ergebnis. Es werden immer noch Nachnamen ohne Vornamen angezeigt.
zwangseinweisung
zwangseinweisung 25.12.2016 aktualisiert um 19:06:12 Uhr
Goto Top
zwangseinweisung ist aus dem Suff heraus entstanden :D
wiesi200
wiesi200 25.12.2016 aktualisiert um 19:26:24 Uhr
Goto Top
Mach aus dem and ein or
Bei and darf im Datensatz weder ein Vor- noch Nachname stehen. Somit werden nur kpl. leere Datensätze rausgefiltert.

Edit: wie weit bist du eigentlich mit der Ausbildung?
zwangseinweisung
zwangseinweisung 25.12.2016 um 20:15:10 Uhr
Goto Top
Hm.... also.... ich bin zu blöd.... wenn ich das "AND" in "OR" ändere bekomme ich immer noch das selbe Ergebnis. Einige Namen tauchen immer noch ohne Vornamen auf. Keine Ahnung was ich schon alles probiert habe. von "select blah as blub" bis hin zu joins.

Die Ausbildung ist nächsten Sommer zuende
wiesi200
Lösung wiesi200 25.12.2016 um 20:41:44 Uhr
Goto Top
versuch mal
WHERE `Vorname` <>'' and `Nachname`<>''   
AndreasHoster
AndreasHoster 25.12.2016 um 21:00:07 Uhr
Goto Top
Du weist was das * beim Select bedeutet?
Deine obere Select Anweisung listet nur VORHANDENE Vornamen / Nachnamen Kombinationen in zufälliger Reihenfolge auf.
Aber Du solltest doch zufällige Vornamen / Nachnamenkombinationen erzeugen, oder?

Also Vornamen und Nachnamen einzeln holen (und leere rausfiltern) und dann kombinieren.
zwangseinweisung
zwangseinweisung 25.12.2016 um 21:52:54 Uhr
Goto Top
schon, "select *" zieht alles aber ich nutze ja "rand()" in der abfrage was die Ergebnisse durcheinander würfelt (auch recht gut sogar)
zwangseinweisung
zwangseinweisung 25.12.2016 um 21:56:47 Uhr
Goto Top
Großartig! Es funktioniert, Das war es! "<>" kannte ich noch nicht. Wo gibts Docs dazu?

Also hier die ganze Abfrage:

Select * from names WHERE `vorname` <>'' and `nachname`<>'' ORDER by RAND() LIMIT 250  
wiesi200
wiesi200 25.12.2016 um 22:13:57 Uhr
Goto Top
Er hat aber recht, es werden nur die einzelnen DB Einträge zufällig durcheinander gewürfelt und nicht zufällige Namenskombinationen erschaffen.
Hier musst du mit Namen Vornamen und Nachnamen separat abfragen. Und dann zusammensetzen.
wiesi200
wiesi200 25.12.2016 um 22:18:32 Uhr
Goto Top