Drukowana wersja tematu

Kliknij tu, aby zobaczyć temat w orginalnym formacie

Forum PHP.pl _ Bazy danych _ Kopia bazy i Jednoczesne wyczyszczenie kolumny

Napisany przez: fcppl 17.09.2020, 15:53:37

Witam,

Mam nietypową sytuacje.

Czy da się zrobić kopie bazy danych tak ze: Baza posiada 15 tabeli z czego do kopi pobieram 10 (przez phpmyadmin) i czy podczas pobierania kopi da się jednocześnie wyczyścić jedną kolumnę? lub czy da się wyczyścić kolumnę posiadając już kopie w pliku xxx.sql np: przez konsolę linuxa?

Lub czy jest jakiś inny sposób?

Sytuacją jest taka że muszę już wgrać kopie bazy z wyczyszczoną jedną kolumną (nie mogę najpierw wgrać i później wyczyścić w phpmyadmin)

Robię to cyklicznie dwa - trzy razy na tydzień więc pobieranie kopii, wgranie do testowej bazy, wyczyszczenie kolumny i dopiero wgranie do docelowej bazy jest kłopotliwe.

Dziękuję za pomoc

Napisany przez: Pyton_000 17.09.2020, 21:14:15

Mółbyś sobie napisac jakiś skrypt pythona który wyczyści ci konkretną kolumnę w dumpie.

Ew. pokaż 1 insert do tej tabelki i powiedz której kolumny nie chcesz.

Napisany przez: fcppl 18.09.2020, 08:49:22

Zaznaczę tylko ze nie chce usunąć kolumny tylko ja wyczyścić z danych smile.gif

Nazwa tabeli "Produkty" przy pobieraniu kopi chce wyczyścić kolumnę "prod_av_ordered"


Napisany przez: czachor 18.09.2020, 12:02:56

Chyba spróbowałbym użyć np. Notepad++ i search&replace w oparciu o regexpa. Struktura zapytań pewnie stała, więc kwestia tylko odpowiedniego dopasowania do konkretnego fragmentu, np. coś w stylu: zastąp wszystko między 5 wystąpieniem apostrofów '' wartością NULL.

Napisany przez: trueblue 18.09.2020, 12:14:43

Możesz zmodyfikować zrzut bazy tak, aby przed DROP/CREATE następnej tabeli dodać UPDATE zmieniający wartość pola na NULL.
Przez chwilę dane będą, ale jednak import nie będzie dokonany w całości (chyba, że to jedyna/ostatnia tabela w zrzucie).

Napisany przez: fcppl 19.09.2020, 18:06:41

Cytat(trueblue @ 18.09.2020, 13:14:43 ) *
Możesz zmodyfikować zrzut bazy tak, aby przed DROP/CREATE następnej tabeli dodać UPDATE zmieniający wartość pola na NULL.
Przez chwilę dane będą, ale jednak import nie będzie dokonany w całości (chyba, że to jedyna/ostatnia tabela w zrzucie).


Moge prosic jakis przyklad takiej modyfikacji?

Napisany przez: trueblue 19.09.2020, 18:29:46

Ale czego konkretnie?

Znajdujesz fragment:

  1. CREATE TABLE IF NOT EXISTS `nazwa_tabeli_nastepnej_po_Produkty`
  2. ....


i przed nim dodajesz:
  1. UPDATE `Produkty` SET `prod_av_ordered`=NULL;


Być może u Ciebie fragment do znalezienia wygląda trochę inaczej, może brakować IF NOT EXISTS lub może być przed nim komentarz (więc UPDATE przed komentarzem).

Całość możesz wykonać albo jakimś skryptem, albo pokombinować z linii poleceń.

Powered by Invision Power Board (http://www.invisionboard.com)
© Invision Power Services (http://www.invisionpower.com)