MariaDB Windows-Spezifika
Ich entwickle unter Windows 10 und bei der Migration von MariaDB-Datenbanken zwischen der Windows- und Linux-Welt in beide Richtungen sind mir folgende Besonderheiten aufgefallen:
Datenbankimport unter Windows
Export einer fiktiven Datenbank namens test unter Linux ...
sudo mysqldump test > test.sql
... und in etwas elaborierterer Form mit Kompression der Daten:
sudo mysqldump --no-autocommit --single-transaction=TRUE test | gzip -9 > test.sql.gz
Der Schalter --no-autocommit beschleunigt den Export großer Datenbanken deutlich und --single-transaction=TRUE stellt einen konsistenten Export der Daten sicher.
Der Import der Datenbank unter Linux kann wie folgt bewerkstelligt werden:
sudo mysql test < test.sql
oder alternativ mit
sudo mysqlimport test test.sql
- unter der Annahme, dass die Datenbank test existent ist.
Nur der Import unter Windows funktioniert aus diversen Gründen so nicht - hier bietet sich folgende alternative Befehlssequenz an:
mysql -u root -p
# (Abfrage des Passworts)
use test;
source test.sql;
Datenbankimport einer unter Windows exportierten Datenbank
Diese Variante bringt das Problem mit sich, dass die Namen der Tabellen unter Windows während des Exports in Kleinbuchstaben umgewandelt werden!
/* Java-Klassennamen KeyValue */
DROP TABLE IF EXISTS `keyvalue`;
/*!40101 SET @saved_cs_client = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `keyvalue` (
`tpye` int(11) DEFAULT NULL,
`key` varchar(255) NOT NULL,
`value` varchar(255) DEFAULT NULL,
...
Die SQL-Tabelle KeyValue wurde mithilfe der OrmLite-Bibliothek angelegt. Die entsprechenden SQL-Statements des Java-Codes können die Tabelle KeyValue nicht finden, da diese nur in der Kleinschreibung keyvalue vorliegt!
Dieses Problem kann unter Linux wie folgt umschifft werden, ...
sudo /etc/mysql/mariadb.conf.d/50-server.cnf
... indem man den SQL-Server anweist, die Groß- und Kleinschreibung zu ignorieren.
[mysqld]
lower_case_table_names=1
Diese Art von Änderung bedingt aber einen Neustart des SQL-Servers.
sudo service mysql restart