Benutzer-Werkzeuge

Webseiten-Werkzeuge


mysql:mysql

Dies ist eine alte Version des Dokuments!


MySQL

Diese Seite enthält allgemeine Hilfen sowie hilfreiche SQL-Befehle für TYPO3-Tabellen.

Terminal-Befehle

MySQL-Server starten/stoppen/neustarten

mysql.server start
mysql.server stop
mysql.server restart

Tritt beim Start von MySQL der Fehler
ERROR! The server quit without updating PID file
auf, müssen die .err-Dateien im Ordner /usr/local/var/mysql/ gelöscht werden.

SQL-Import über Terminal

Wenn die SQL-Datei zu groß für einen Import über phpmyadmin ist. Leere Datenbank muss bereits vorhanden sein.

mysql -u Username -p Datenbankname < beispiel.sql

Bei Mittwald und ggf. anderen Anbietern muss noch der Hostname ergänzt werden:

mysql -u Username -p -h db1234.mydbserver.com Datenbankname < beispiel.sql

SQL-Befehle

Suchen/Ersetzen von Teilstrings innerhalb einzelner DB-Felder

UPDATE tt_content
SET bodytext = REPLACE(bodytext, 'class="old-btn"', 'class="c-btn  c-btn--primary"')
WHERE bodytext LIKE ('%class="old-btn"%');

RTE Accessibility Icons ersetzen

Mit TYPO3 v7 wurden die Barrierefreiheit-Icons für Links im RTE an andere Stelle im Extension-Verzeichnis verschoben, um die Struktur mit dem Rest des TYPO3-Kerns zu vereinheitlichen.

UPDATE tt_content 
  SET bodytext = REPLACE(bodytext, 
    'rtehtmlarea/res/accessibilityicons/img/', 
    'rtehtmlarea/Resources/Public/Images/');

Quelle: Stack Overflow: RTEs accessibilityicons missing in TYPO3 7.6

Mit der Aktualisierung auf TYPO3 v8 müssen Pfade möglicherweise erneut angepasst werden, da die Extension rtehtmlarea nicht mehr zum TYPO3-Kern gehört und ggf. nachinstalliert werden muss. Statt /typo3/sysext/rtehtmlarea/ lautet der Pfad dann /typo3conf/ext/rtehtmlarea/.

Suchen/Ersetzen exakter Werte in Feldern

Hilfreich, um z.B. den Wert 1 in einem Feld zu finden, nicht aber 12.

[[:<:]]Exakter Treffer[[:>:]] 

Ausgabe aller vorhandenen Feldwerte (ohne Mehrfachnennung)

SELECT * FROM `tt_content` GROUP BY `CType`
SELECT * FROM `pages` GROUP BY `backend_layout`

Suche nach doppelten Einträgen

Hier am Beispiel mehrfach importierter Newsbeiträge:

SELECT uid,title,externalurl, COUNT(*)
FROM `tx_news_domain_model_news`
GROUP BY title,externalurl
HAVING COUNT(*) > 1
mysql/mysql.1523298759.txt.gz · Zuletzt geändert: 2018/04/09 20:32 von admin