php-resource



Zurück   PHP-Scripte PHP-Tutorials PHP-Jobs und vieles mehr > Entwicklung > SQL / Datenbanken
 

Login

 
eingeloggt bleiben
star Jetzt registrieren   star Passwort vergessen
 

 

 


SQL / Datenbanken Probleme mit SQL? Hier könnt ihr eure Fragen zu SQL (MySQL, PostgreSQL, MS-SQL und andere ANSI-SQL Server) los werden.

Antwort
 
LinkBack Themen-Optionen Bewertung: Bewertung: 3 Stimmen, 5,00 durchschnittlich.
  #1 (permalink)  
Alt 09-06-2006, 10:14
Boron
 Registrierter Benutzer
Links : Onlinestatus : Boron ist offline
Registriert seit: Aug 2004
Beiträge: 191
Boron ist zur Zeit noch ein unbeschriebenes Blatt
Standard SELECT Wert einer Tabelle, der nicht in einer anderen ist

Hi,

ich möchte von meiner MySQL-Tabelle alle Felder einer Tabelle haben, deren Werte nicht in einer anderen (ähnlichen) Tabelle sind.

Es sind zwei Tabellen vorhanden:

table1: id,name

table2: id,name

Also alle Felder von table1 sollen zurückgegeben werden, wo der Wert von "name" nicht in table2 vorhanden ist.

Wie realisiere ich das?

Mein Versuch:

PHP-Code:
$qry mysql_query("SELECT id,name FROM `table1`
                    WHERE name NOT IN (SELECT name FROM `table2`)"
);
if(
mysql_num_rows($qry) != 0)
{
    echo 
"Mindestens ein Feld nicht in table2 vorhanden!";

hat nicht funktioniert. Da wird nichts ausgegeben.

Vielen Dank für eure Hilfe
Boron
Mit Zitat antworten
  #2 (permalink)  
Alt 09-06-2006, 10:39
Wurzel
 Master
Links : Onlinestatus : Wurzel ist offline
Registriert seit: Jul 2002
Ort: double-u-upper-valley
Beiträge: 7.477
Wurzel ist zur Zeit noch ein unbeschriebenes Blatt
Standard

JOINS - das leidige Thema (mehrere Tabellen abfragen)

^^ schau dir die beispiele an
__________________
Kissolino.com
Mit Zitat antworten
  #3 (permalink)  
Alt 09-06-2006, 11:14
Boron
 Registrierter Benutzer
Links : Onlinestatus : Boron ist offline
Registriert seit: Aug 2004
Beiträge: 191
Boron ist zur Zeit noch ein unbeschriebenes Blatt
Standard

Ja....

Aber bei mir sind die ids nicht gleich.

Kannst du mir bitte sagen, wie es richtig heißen muss?
Mit Zitat antworten
  #4 (permalink)  
Alt 09-06-2006, 12:44
Jesseblue
 Junior Member
Links : Onlinestatus : Jesseblue ist offline
Registriert seit: May 2006
Beiträge: 78
Jesseblue ist zur Zeit noch ein unbeschriebenes Blatt
Standard

Eine dritte Tabelle erstellen die die Schlüssel beider Tabellen beinhaltet (siehe N:M Beziehungen modellieren und abfragen) und dadrauf dann eine SQL-Anweisung absetzen. Nur das du hier nicht mir "="-Operator sondern "!="-Operator arbeitest.
Mit Zitat antworten
  #5 (permalink)  
Alt 09-06-2006, 15:45
Boron
 Registrierter Benutzer
Links : Onlinestatus : Boron ist offline
Registriert seit: Aug 2004
Beiträge: 191
Boron ist zur Zeit noch ein unbeschriebenes Blatt
Standard

Hi,

vielen Danken für deine Antwort.

Zitat:
Eine dritte Tabelle erstellen die die Schlüssel beider Tabellen beinhaltet
Muss ich eine weitere Tabelle erstellen? Oder komm ich da nicht drumrum?
Mit Zitat antworten
  #6 (permalink)  
Alt 09-06-2006, 22:49
mai
 Junior Member
Links : Onlinestatus : mai ist offline
Registriert seit: Jun 2006
Beiträge: 98
mai ist zur Zeit noch ein unbeschriebenes Blatt
Standard

Das folgende Beispiel im mysql Manual suchen und anpassen (wenn ich die Frage richtig verstehe: Alle Datensätze finden, .....)
PHP-Code:
SELECT table1.* FROM table1
  LEFT JOIN table2 ON table1
.id=table2.id
  WHERE table2
.id IS NULL
PS die mysql-Formulierung in der Frage scheint zutreffend, ausser wenn t2.name=NULL vorkommt. Ansonsten mysql_error() ? var_dump(mysql_num_rows..)) ?

Geändert von mai (09-06-2006 um 23:08 Uhr)
Mit Zitat antworten
  #7 (permalink)  
Alt 10-06-2006, 10:27
Boron
 Registrierter Benutzer
Links : Onlinestatus : Boron ist offline
Registriert seit: Aug 2004
Beiträge: 191
Boron ist zur Zeit noch ein unbeschriebenes Blatt
Standard

PHP-Code:
// Leute, die nicht mehr in der Mitgliederliste sind
$qry mysql_query("SELECT t1.id,
                           t1.nachname AS nachname,
                           t1.vorname AS vorname
                    FROM "
.$table["leute"]." AS t1
                    LEFT JOIN "
.$table["mitglieder"]." AS t2 
                      ON t1.nachname=t2.nachname AND t1.vorname=t2.vorname
                    WHERE t2.nachname IS NULL
                    "
);
echo 
mysql_errno() . ": " mysql_error() . "\n"
gibt

Zitat:
1267: Illegal mix of collations (latin1_german2_ci,IMPLICIT) and (latin1_general_ci,IMPLICIT) for operation '='
zurück.

Was tun?

Wie gesagt, die Ids sind unterschiedlich - ich kann die zwei Tabellen halt nur anhand der Werte, die in den Feldern nachname und vorname vorkommen, überprüfen.

edit: Ach bin ich blöd, dann sollte ich natürlich die zwei Kollationen gleichsetzen.... danke!

Btw, welche Kollation sollte man nehmen? Die Namen werden eh urlencoded gespeichert.

So funktioniert es jedenfalls. Vielen Dank.

Geändert von Boron (10-06-2006 um 10:42 Uhr)
Mit Zitat antworten
Antwort

Lesezeichen


Aktive Benutzer in diesem Thema: 1 (Registrierte Benutzer: 0, Gäste: 1)
 

Themen-Optionen
Thema bewerten
Thema bewerten:

Forumregeln
Es ist Ihnen nicht erlaubt, neue Themen zu verfassen.
Es ist Ihnen nicht erlaubt, auf Beiträge zu antworten.
Es ist Ihnen nicht erlaubt, Anhänge hochzuladen.
Es ist Ihnen nicht erlaubt, Ihre Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are an


PHP News

Projektmanagement Damals und Heute
Projektmanagement Damals und HeuteWerfen Sie einen Blick auf das, was sich verändert hat, und entdecken Sie, wo die Zukunft dieses Gebietes hinsteuert.

18.01.2021 | Berni

Arbeitsmanagement-Tools
Arbeitsmanagement-ToolsWarum jedes Team Arbeitsmanagement-Tools benötigt. Man schätzt, dass 25% eines durchschnittlichen Mitarbeiter-Tages durch ineffiziente Arbeit vergeudet werden.

11.12.2020 | Berni


 

Aktuelle PHP Scripte

PHP Newsletter Script SuperWebMailer ansehen PHP Newsletter Script SuperWebMailer

Die webbasierte PHP Newsletter Software SuperWebMailer ist die optimale Lösung zur Durchführung eines erfolgreichen E-Mail-Marketings. Zur Nutzung des PHP Script-Pakets ist eine eigene Webpräsenz/Server mit PHP 5 oder neuer, MySQL 4 oder neuer und die

29.04.2021 mirko_swm | Kategorie: PHP/ Mail
OXID eShop

Mit OXID eshop bieten wir Ihnen eine modulare und skalierbare Internet Shopping Software mit einem hervorragenden Preis-/Leistungsverhältnis.

29.04.2021 eric.jankowfsky@ | Kategorie: PHP/ Shops
PHP-Login

Die Aufgabenstellung bestand darin, ein einfaches Login-Script zu erstellen, dass schnell und universell auf jeder Webseiten eingebaut werden kann. Der Schwerpunkt lag dabei auf der Entwicklung eines universell einsetzbarem Modul für den Login und zur

05.04.2021 Wallhalla | Kategorie: PHP/ Kundenverwaltung
 Alle PHP Scripte anzeigen

Alle Zeitangaben in WEZ +2. Es ist jetzt 00:39 Uhr.