• Hallo liebe Userinnen und User,

    nach bereits längeren Planungen und Vorbereitungen sind wir nun von vBulletin auf Xenforo umgestiegen. Die Umstellung musste leider aufgrund der Serverprobleme der letzten Tage notgedrungen vorverlegt werden. Das neue Forum ist soweit voll funktionsfähig, allerdings sind noch nicht alle der gewohnten Funktionen vorhanden. Nach Möglichkeit werden wir sie in den nächsten Wochen nachrüsten. Dafür sollte es nun einige der Probleme lösen, die wir in den letzten Tagen, Wochen und Monaten hatten. Auch der Server ist nun potenter als bei unserem alten Hoster, wodurch wir nun langfristig den Tank mit Bytes vollgetankt haben.

    Anfangs mag die neue Boardsoftware etwas ungewohnt sein, aber man findet sich recht schnell ein. Wir wissen, dass ihr alle Gewohnheitstiere seid, aber gebt dem neuen Board eine Chance.
    Sollte etwas der neuen oder auch gewohnten Funktionen unklar sein, könnt ihr den "Wo issn da der Button zu"-Thread im Feedback nutzen. Bugs meldet ihr bitte im Bugtracker, es wird sicher welche geben die uns noch nicht aufgefallen sind. Ich werde das dann versuchen, halbwegs im Startbeitrag übersichtlich zu halten, was an Arbeit noch aussteht.

    Neu ist, dass die Boardsoftware deutlich besser für Mobiltelefone und diverse Endgeräte geeignet ist und nun auch im mobilen Style alle Funktionen verfügbar sind. Am Desktop findet ihr oben rechts sowohl den Umschalter zwischen hellem und dunklem Style. Am Handy ist der Hell-/Dunkelschalter am Ende der Seite. Damit sollte zukünftig jeder sein Board so konfigurieren können, wie es ihm am liebsten ist.


    Die restlichen Funktionen sollten eigentlich soweit wie gewohnt funktionieren. Einfach mal ein wenig damit spielen oder bei Unklarheiten im Thread nachfragen. Viel Spaß im ngb 2.0.

[SQL] Komplette Spalte ersetzen mithilfe einer Zuordnungstabelle

BurnerR

Bot #0384479

Registriert
20 Juli 2013
Beiträge
5.504
Ich habe hier einen table T, der hat u.a. eine Spalte 'internal_id' mit unique Einträgen "AAAA", "AAAB", "AAAC", ...
Desweiteren habe ich eine zuordnungstabelle mit den Spalten ['internal_id', 'new_id'] mit Einträgen ["AAAA", "XXXX"]. ["AAAB", "XXX1"], ["AAAC", "XXX2"]. Die Einträge in 'new_id' sind auch unique.
Wie kann ich (in mysql) alle Einträge in internal_id im table T durch die zugehörigen in new_id ersetzen?
Muss ich da mit den spaltennamen herumschrauben? Mich würde interessieren, wie das mit UPDATE und SELECT geht.
Gerne auch, wie das hypothetisch mit PostgreSQL ginge - rein aus Interesse.
 

KaPiTN

♪♪♫ wild at heart ♪♫♫♪

Registriert
14 Juli 2013
Beiträge
29.138
Scheint nicht mehr als dies zu sein:

Update T set internal_id =(Select new_id from T2 Where internal_id=T.internal_id) ;


Ich habe gerade folgendes gemacht:
[src=mysql]
create table T(internal_id varchar(5));
insert into T(internal_id ) values('AAAAA');
insert into T(internal_id ) values('AAAAB');
insert into T(internal_id ) values('AAAAC');
insert into T(internal_id ) values('AAAAD');

create table T2(internal_id varchar(5),new_id varchar(5));
insert into T2 (internal_id,new_id) values('AAAAA', 'XXXX1');
insert into T2 (internal_id,new_id) values('AAAAB', 'XXXX2');
insert into T2 (internal_id,new_id) values('AAAAC', 'XXXX3');
insert into T2 (internal_id,new_id) values('AAAAD', 'XXXX4');

select * from T;
Update T set internal_id =(Select new_id from T2 Where internal_id=T.internal_id) ;
select * from T;

[/src]

Output:
AAAAA
AAAAB
AAAAC
AAAAD
XXXX1
XXXX2
XXXX3
XXXX4
 

BurnerR

Bot #0384479

Registriert
20 Juli 2013
Beiträge
5.504
  • Thread Starter Thread Starter
  • #3
Ah, ja vielen Dank für die Schützenhilfe!
Hab mir schon fast gedacht, dass es nicht so schwierig ist... es war sehr montagig gestern :o :beer:
 

exomo

NGBler

Registriert
1 Aug. 2015
Beiträge
129
Das funktioniert aber nur, wenn die neuen IDs nicht schon in den alten enthalten sind. In der folgenden Variation kann das Update nicht ausgeführt werden weil keys (temporär) doppelt wären.
[src=mysql]create table T(internal_id varchar(5) PRIMARY KEY);
insert into T(internal_id ) values('AAAAA');
insert into T(internal_id ) values('AAAAB');
insert into T(internal_id ) values('AAAAC');
insert into T(internal_id ) values('AAAAD');

create table T2(internal_id varchar(5),new_id varchar(5));
insert into T2 (internal_id,new_id) values('AAAAA', 'AAAAD');
insert into T2 (internal_id,new_id) values('AAAAB', 'AAAAC');
insert into T2 (internal_id,new_id) values('AAAAC', 'AAAAA');
insert into T2 (internal_id,new_id) values('AAAAD', 'AAAAB');

select * from T;
Update T set internal_id =(Select new_id from T2 Where internal_id=T.internal_id) ;
select * from T;[/src]
Wenn das eine Voraussetzung ist musst du vermutlich tatsächlich die Spalten modifizieren:
[src=mysql]create table T(internal_id varchar(5) PRIMARY KEY,
val INT);
insert into T(internal_id, val ) values('AAAAA', 1);
insert into T(internal_id, val ) values('AAAAB', 2);
insert into T(internal_id, val ) values('AAAAC', 3);
insert into T(internal_id, val ) values('AAAAD', 4);

create table T2(internal_id varchar(5),new_id varchar(5));
insert into T2 (internal_id,new_id) values('AAAAA', 'AAAAD');
insert into T2 (internal_id,new_id) values('AAAAB', 'AAAAC');
insert into T2 (internal_id,new_id) values('AAAAC', 'AAAAA');
insert into T2 (internal_id,new_id) values('AAAAD', 'AAAAB');

select * from T;
ALTER TABLE T ADD new_id varchar(5) AFTER internal_id;
UPDATE T JOIN T2 ON T.internal_id = T2.internal_id
SET T.new_id = T2.new_id;
ALTER TABLE T DROP internal_id;
ALTER TABLE T CHANGE new_id internal_id varchar(5) PRIMARY KEY;
select * from T;[/src]
(spalte val dient nur zur Veranschaulichung)

Oder noch einfacher: den primary key entfernen und hinterher wieder hinzufügen:
[src=mysql]ALTER TABLE T DROP PRIMARY KEY;
UPDATE T JOIN T2 ON T.internal_id = T2.internal_id
SET T.internal_id = T2.new_id;
ALTER TABLE T MODIFY internal_id varchar(5) PRIMARY KEY;[/src]
 
Zuletzt bearbeitet:
Oben