Bestimmte MySQL-Spalten einer Tabelle exporieren, sie ändern und als zusätzliche Werte importieren
Hi,
ich benutze Xampp und suche eine Möglichkeit per phpmyadmin (SQL-Befehl) betimmte Spalten einer Tabelle zu kopieren/exportieren um diese ändern zu können und geändert dann wieder in die Tabelle zu importieren ohne die vorhandenen Werte zu überschreiben.
Da ich 37 Einträge kopieren und abgeändert importieren muss, möchte ich dies ungern von Hand machen müssen, indem ich jeden Eintrag einzeln aufrufe ihn ändere und als neuen Eintrag abspeichere!
Es soll nur die Spalte template_name geändert werden.
Die Tabelle heißt gm_boxes, die darin enthaltenen Spalten (?) heißen boxes_id, tamplate_name, box_name, position und box_status.
Eine kleine Vorschau der Tabelle ist angehängt.
ich benutze Xampp und suche eine Möglichkeit per phpmyadmin (SQL-Befehl) betimmte Spalten einer Tabelle zu kopieren/exportieren um diese ändern zu können und geändert dann wieder in die Tabelle zu importieren ohne die vorhandenen Werte zu überschreiben.
Da ich 37 Einträge kopieren und abgeändert importieren muss, möchte ich dies ungern von Hand machen müssen, indem ich jeden Eintrag einzeln aufrufe ihn ändere und als neuen Eintrag abspeichere!
Es soll nur die Spalte template_name geändert werden.
Die Tabelle heißt gm_boxes, die darin enthaltenen Spalten (?) heißen boxes_id, tamplate_name, box_name, position und box_status.
Eine kleine Vorschau der Tabelle ist angehängt.
Bitte markiere auch die Kommentare, die zur Lösung des Beitrags beigetragen haben
Content-ID: 192031
Url: https://administrator.de/contentid/192031
Ausgedruckt am: 22.11.2024 um 13:11 Uhr
11 Kommentare
Neuester Kommentar
Hi Oli-nux,
Du machst eine Kopie der Tabelle gm_boxes, z.B. gm_boxes2.
Anschließend änderst du die Werte in der Spalte gm_boxes2.template_name.
Via phpMyAdmin -> SQL führst du folg. Befehl aus:
Gruß
Günni
Es soll nur die Spalte template_name geändert werden.
Du machst eine Kopie der Tabelle gm_boxes, z.B. gm_boxes2.
Anschließend änderst du die Werte in der Spalte gm_boxes2.template_name.
Via phpMyAdmin -> SQL führst du folg. Befehl aus:
update gm_boxes, gm_boxes2 set gm_boxes.template_name = gm_boxes2.template_name
where gm_boxes.id = gm_boxes2.id
where gm_boxes.id = gm_boxes2.id
Gruß
Günni
Zitat von @Oli-nux:
> Zitat von @Guenni:
> ----
> Du machst eine Kopie der Tabelle gm_boxes, z.B. gm_boxes2.
>
Nee, weil dadurch dann die Struktur des System verändert werden würde!
Warum?
Weil es dann ja eine weitere Tabelle gibt die es jetzt nicht gibt und ich am System selber nichts ändere.
Es geht hier - wie ersichtlich - um ein Shop-System.
Die Änderungen müssen in dieselbe Tabelle, aber eben nur als eigenständige Werte.
> Zitat von @Guenni:
> ----
> Du machst eine Kopie der Tabelle gm_boxes, z.B. gm_boxes2.
>
Nee, weil dadurch dann die Struktur des System verändert werden würde!
Warum?
Weil es dann ja eine weitere Tabelle gibt die es jetzt nicht gibt und ich am System selber nichts ändere.
Es geht hier - wie ersichtlich - um ein Shop-System.
Die Änderungen müssen in dieselbe Tabelle, aber eben nur als eigenständige Werte.
Hi Oli-nux,
die Struktur deines Systems wird doch nicht geändert. Die Kopie der Tabelle dient ja nur dazu, die Werte
der betreffenden Spalte zu ändern. Das ist das einzig händische, was du machen musst. Der SQL-Befehl macht
dann ein Update auf deine Originaltabelle mit den Werten der Kopie. Danach kannst du die Kopie wieder löschen.
Gruß
Günni
Nabend,
das kann doch auch in einem Query zusammengefasst werden:
Das Feld `id` ist hier vom Type INT und AUTO_INCREMENT,
`template` und `name` sind einfach "CHAR(33)".
Das SELECT muss dann nur noch mit einer WHERE-Klausel begranzt werden z.B. "WHERE `template`='gambio'"
~Arano
das kann doch auch in einem Query zusammengefasst werden:
INSERT ... SELECT ...
mysql> use test;
Database changed
mysql> select * from `werte`;
+----+----------+---------+
| id | template | name |
+----+----------+---------+
| 1 | aaa | arano |
| 2 | aaa | oli-nux |
+----+----------+---------+
2 rows in set (0,00 sec)
mysql> insert into `werte` (`template`,`name`) SELECT 'bbb',`name` FROM `werte`;
Query OK, 2 rows affected (0,01 sec)
Records: 2 Duplicates: 0 Warnings: 0
mysql> select * from `werte`;
+----+----------+---------+
| id | template | name |
+----+----------+---------+
| 1 | aaa | arano |
| 2 | aaa | oli-nux |
| 3 | bbb | arano |
| 4 | bbb | oli-nux |
+----+----------+---------+
4 rows in set (0,00 sec)
mysql>
`template` und `name` sind einfach "CHAR(33)".
Das SELECT muss dann nur noch mit einer WHERE-Klausel begranzt werden z.B. "WHERE `template`='gambio'"
~Arano