Kevin_ Geschrieben 25. November 2010 Teilen Geschrieben 25. November 2010 Hallo zusammen, ich bin dabei eine kleine Datenband mit MySql aufzustellen, die als Klausur einfließt! Ich denke ich stelle einfach mal das Schema rein, in der Hoffnung das mit wer helfen kann! create table Tickets ( ticketnr int not null, person varchar (100), email varchar (100), telnumer int, eventnr int not null, primary key (ticketnr) foreign key (eventnr) references Event (eventnr) ); insert into Tickets (ticketnr, person, email, telnumer, eventnr) values (1, "Heinz", "heinz@gmx.de", 01514332, 2), (2, "Karl", "Karl@web.de", 003343, 1), (3, "Pjotr", "Pjotr@web.de", 0343556, 2); create table Event (eventnr int not null, datum DATE, preis int, ort varchar (30), primary key (eventnr) ); insert into Event (eventnr, datum, preis, ort) values (1, "2012-04-13", 25, "Petersdom"), (2, "2012-06-01", 30, "Peterplatz"), (3, "2012-07-31", 27, "Vatikanische Gärten"); create table Eventliste (eventnr int not null, event varchar (30), primary key (event) ); insert into Eventliste (eventnr, event) values (1, "Rocking Pope"), (2, "Rome Apocalyptic"), (3, "Garden Eden"); create table Ticketliste (ticketnr int not null, eventnr int not null, primary key (ticketnr, eventnr) ); insert into Ticketliste (ticketnr, eventnr) values (1, 2), (2, 1), (3, 2); Ich weiß das dort zb noch keine Verknüpfungen durchgeführt wurden und das dort folgende fehler auftreten: 1.-[hi(=belieber Datenbank name)] ERROR 1064: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'foreign key (eventnr) references Event (eventnr) )' at line 9 2.-[hi] ERROR 1146: Table 'db_ticketverkauf.tickets' doesn't exist 3.-[hi] ERROR 1064: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'index IX_wird zugeordnet )' at line 7 4.-[hi] ERROR 1062: Duplicate entry '1' for key 1 5.-[hi] ERROR 1050: Table 'eventliste' already exists 6.-[hi] ERROR 1062: Duplicate entry '1' for key 1 7.-[hi] ERROR 1050: Table 'ticketliste' already exists 8.-[hi] ERROR 1062: Duplicate entry '1-2' for key 1 Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
lupo49 Geschrieben 25. November 2010 Teilen Geschrieben 25. November 2010 create table Tickets ( ticketnr int not null, person varchar (100), email varchar (100), telnumer int, eventnr int not null, primary key (ticketnr) foreign key (eventnr) references Event (eventnr) ); Wie willst du auf Event referenzieren, wenn Event noch nicht existiert? Hier fehlt auch ein Komma in der Zeile "primary key (ticketnr)". Der Rest ist syntaktisch korrekt bzw. läuft so durch. Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
Kevin_ Geschrieben 25. November 2010 Autor Teilen Geschrieben 25. November 2010 ok, also das "Event" zb unter die zu referendierende Tabelle setzen? Aber kannst du mir helfen mit diesen Verknüpfungen, mit dem Befehl "Index_IX" Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
lupo49 Geschrieben 25. November 2010 Teilen Geschrieben 25. November 2010 also das "Event" zb unter die zu referendierende Tabelle setzen? Ja, oder die Referenz erst nach dem Erstellen von Event aktivieren. Aber kannst du mir helfen mit diesen Verknüpfungen, mit dem Befehl "Index_IX" Oben ist keine betreffende SQL-Query angegeben, die Index_IX enthält. Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
Kevin_ Geschrieben 25. November 2010 Autor Teilen Geschrieben 25. November 2010 ich weiß Ich weiß das dort zb noch keine Verknüpfungen durchgeführt wurden Muss mit jeder Tabelle noch durchgeführt werden, nur ist das mein großes Problem Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
Corto -sX- Geschrieben 26. November 2010 Teilen Geschrieben 26. November 2010 MySQL :: MySQL 5.1 Referenzhandbuch :: 13.1.4 CREATE INDEX suchst du das? CREATE INDEX index_name ON tbl_name (selektives_column); das machst du mit den selektiven Spalten deiner Tabellen. Was selektiv ist siehst du daran über welche Spalten in der where du eine eindeutigkeit erzielst.. ID oder LfndNR sind solche Kandidaten.. Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
Empfohlene Beiträge
Dein Kommentar
Du kannst jetzt schreiben und Dich später registrieren. Wenn Du ein Konto hast, melde Dich jetzt an, um unter Deinem Benutzernamen zu schreiben.