[GastForen Programmierung/Entwicklung PHP und MySQL SQL REPLACEoder Alternativen

  • Suche
  • Hilfe
  • Lesezeichen
  • Benutzerliste
Themen
Beiträge
Moderatoren
Letzter Beitrag

SQL REPLACEoder Alternativen

Pozor
Beiträge gesamt: 892

16. Mär 2004, 07:48
Beitrag # 1 von 5
Bewertung:
(1029 mal gelesen)
URL zum Beitrag
Beitrag als Lesezeichen
Hallo,

mein Problem ist folgendes:

Ich habe in einer Tabelle diverse Einträge.
Nun möchte ich weitere einfügen, doch möglicherweise sind manche der neuen Eintäge schon in der Tabelle vorhanden und ich möchte keine doppelten Einträge produzieren.

REPLACE (Nach Definition):
REPLACE works exactly like INSERT, except that if an old record in the table has the same value as a new record on a UNIQUE index or PRIMARY KEY, the old record is deleted before the new record is inserted.

In der Tabelle eine id (PRIMARY KEY). Wie kann ich mein Problem mit einer MYSQL Anweisung lösen?

Tabellenstruktur:
id primary int(11) auto_increment
status int(1)
owner int(11)
timestamp timestamp(14)

folgendes funktioniert nicht (wiederholte Ausführung):

$query = "REPLACE tb_test (owner,status) VALUES (1,2)";
$result = mysql_query($query,$link);
if(2 == mysql_affected_rows())
{
echo 'Replace done!';
}else
{
echo 'New insert!';
}

es funktioniert, wenn man die erste Zeile ändert:

$query = "REPLACE tb_test (id,owner,status) VALUES (1,1,2)"; //zusätzlich id (PRIMARY KEY)

Das Problem ist, dass bei einem neuen Eintrag die ID natürlich NICHT manuell gesetzt werden sollte (auto_increment)... Wie kann man das umgehen? jedesmal die nächste einzusezende ID abzufragen? (Aufwand für DB hoch?)


Gruss Pozor

(Dieser Beitrag wurde von Pozor am 16. Mär 2004, 07:56 geändert)
X

SQL REPLACEoder Alternativen

oesi50
  
Beiträge gesamt: 2315

16. Mär 2004, 11:56
Beitrag # 2 von 5
Beitrag ID: #75231
Bewertung:
(1029 mal gelesen)
URL zum Beitrag
Beitrag als Lesezeichen
hi Pozor,
die Lösung hast Du schon geschrieben:
"a new record on a UNIQUE index or PRIMARY KEY"

hier gibt es 2 Möglichkeiten, entweder Du legst für die Spalte 'owner' zusätzlich einen UNIQUE Index an, oder Du verwendest 'owner' direkt als Primärschlüssel. Die zweite Variante würde ich bevorzugen, da hier nur 1 Index notwendig ist. Ich gehe mal davon aus, daß es ohnehin jeden 'owner' Eintrag nur einmal gibt.
Wozu wird eigentlich die 'ID' verwendet?

zu Deiner Tabellenstruktur:

Gibt es bei Dir -1000000000 bis 1000000000 'owner'? Wenn nein, dann ist es sicher sinnvoller(und performanter) als Datentyp 'mediumint unsigned' zu verwenden. Das sind immer noch 1 bis 16000000 mögliche 'owner'.

CREATE TABLE test (
owner mediumint(8) unsigned NOT NULL default '0',
status tinyint(1) unsigned NOT NULL default '0',
timestamp timestamp(14) NOT NULL,
PRIMARY KEY (owner)
) TYPE=MyISAM;

Grüße Oesi
Ich weiß, dass ich nichts weiß... (Sokrates)


als Antwort auf: [#75198]
(Dieser Beitrag wurde von oesi50 am 16. Mär 2004, 16:18 geändert)

SQL REPLACEoder Alternativen

Pozor
Beiträge gesamt: 892

16. Mär 2004, 21:02
Beitrag # 3 von 5
Beitrag ID: #75310
Bewertung:
(1029 mal gelesen)
URL zum Beitrag
Beitrag als Lesezeichen
hallo,

Ok, ja auf diese Loesung kahm ich auch schon.

Nun ok ev. sollte ich die Tabelle genauer beschreiben.

id INT (11) PRIMARY KEY auto_increment
status INDEX INT(1)
owner INT(11)
auth INT(11)
timestamp TIMESTAMP(14)

Es hat fuer jeder user mehrere Eintraege...
Das mit den Int fuer user und auth ist ok so wies ist (momentan)

Gruss Pozor


als Antwort auf: [#75198]

SQL REPLACEoder Alternativen

oesi50
  
Beiträge gesamt: 2315

16. Mär 2004, 22:50
Beitrag # 4 von 5
Beitrag ID: #75336
Bewertung:
(1029 mal gelesen)
URL zum Beitrag
Beitrag als Lesezeichen
wenn der owner mehrfach in der Tabelle steht, dann hilft nur
UPDATE ... SET ..... WHERE owner = 'xxxx'
sind hier '0 rows affected'
dann ein INSERT .... ausführen.

Grüße Oesi
Ich weiß, dass ich nichts weiß... (Sokrates)


als Antwort auf: [#75198]

SQL REPLACEoder Alternativen

Pozor
Beiträge gesamt: 892

16. Mär 2004, 23:01
Beitrag # 5 von 5
Beitrag ID: #75339
Bewertung:
(1029 mal gelesen)
URL zum Beitrag
Beitrag als Lesezeichen
Hallo,

Ja das ist wie ich es bis anhin geloest hatte, doch ich suchte nach einer Loesung in einem Schritt. Die gibt es anscheinend nicht... darum habe ich Sie nicht gefunden?

Trozdem merci oesi50 fuer dein Einsatz!

Gruss Pozor


als Antwort auf: [#75198]
X

Veranstaltungskalender

Hier können Sie Ihre Anlässe eintragen, welche einen Zusammenhang mit den Angeboten von HilfDirSelbst.ch wie z.B. Adobe InDesign, Photoshop, Illustrator, PDF, Pitstop, Affinity, Marketing, SEO, Büro- und Rechtsthemen etc. haben. Die Einträge werden moderiert freigeschaltet. Dies wird werktags üblicherweise innert 24 Stunden erfolgen.

pdf-icon Hier eine kleine Anleitung hinsichtlich Bedeutung der auszufüllenden Formularfelder.

Veranstaltungen
14.05.2024

Online
Dienstag, 14. Mai 2024, 10.00 - 10.30 Uhr

Webinar

Prozessoptimierung ist ein Teamsport! Keine Software und keine Maschine allein kann Ihnen helfen, die Effizienzpotenziale Ihres Betriebes maximal auszuschöpfen. Von der Auftragsannahme über die Vorstufe und den Druck bis hin zur Weiterverarbeitung – alles muss optimal ineinandergreifen. Apropos Weiterverarbeitung – in vielen Druckbetrieben fristet sie in Sachen Prozessoptimierung immer noch ein Schattendasein. Dabei liegen hier mittlerweile die größten Einsparpotenziale! In einem Webinar von Horizon und Impressed erfahren Sie, wie Sie diese Einsparungen realisieren können. Horizon, bekannt für innovative Lösungen in der Druckweiterverarbeitung, bietet mit iCE LiNK eine Workflowlösung für die Weiterverarbeitung. iCE LiNK überwacht, visualisiert und analysiert Produktionsabläufe und unterstützt bei der Wartung – damit immer alles reibungslos läuft. Den gleichen Anspruch hat der von Impressed entwickelte Impressed Workflow Server – er ist die smarte PDF-Workflow-Lösung für Druckereien, die Datenmanagement, Preflight und Produktionssteuerung übernimmt. Im Webinar zeigen Ihnen die Experten von Horizon und Impressed, wie beide Lösungen im Team die Effizienz und Produktivität Ihres Betriebes steigern können. Melden Sie sich am besten gleich an, wir freuen uns auf Sie! PS: Melden Sie sich in jedem Fall an – sollten Sie zum Termin verhindert sein, erhalten Sie die Aufzeichnung.

kostenlos

Ja

Organisator: Impressed / Horizon

https://www.impressed.de/schulung.php?c=sDetail&sid=327

Einsparpotenziale in der Weiterverarbeitung
Veranstaltungen
16.05.2024

Online
Donnerstag, 16. Mai 2024, 10.00 - 10.30 Uhr

Webinar

Komplizierte, kleinteilige Aufträge; alles sehr speziell; seit Jahren bewährte Prozesse – da können wir nichts standardisieren und automatisieren! Das sagen viele Großformatdrucker – aber stimmt das wirklich, ist dem tatsächlich so? Günther Business Solutions und Impressed treten in einem Webinar den Gegenbeweis an. Experten beider Unternehmen zeigen, wie Großformatdrucker vom Einsatz zweier bewährter Lösungen profitieren können: • von advanter print+sign von Günther Business Solutions, dem ERP-System für den Großformatdruck, dass alle Phasen der Wertschöpfung im Large Format Printing abdeckt • von Impressed Workflow Server, der smarten PDF-Workflow-Lösung für Druckereien, die Datenmanagement, Preflight und Produktionssteuerung übernimmt Über die Kombination beider Lösungen können Großformatdrucker ihre Prozesse mit modernen Workflows Schritt für Schritt automatisieren – und so zügig deutliche Zeit- und Kosteneinsparungen realisieren. Das Webinar sollten Sie sich nicht entgehen lassen – damit Sie keine Effizienzpotenziale mehr liegen lassen. Melden Sie sich am besten gleich an, wir freuen uns auf Sie! PS: Melden Sie sich in jedem Fall an – sollten Sie zum Termin verhindert sein, erhalten Sie die Aufzeichnung.

kostenlos

Nein

Organisator: Impressed / Günther Business Solutions

https://www.impressed.de/schulung.php?c=sDetail&sid=326

Und es geht doch: Automatisierung im Großformatdruck!