Im Zuge der Entwicklung einer REST API mit Python, kommen wir jetzt zu Datenbankmigrationen mit Alembic. Migrationen sind extrem wichtig, wenn du deine Datenbankstruktur im Laufe der Entwicklung ändern willst (z. B. neue Spalten hinzufügen), ohne Daten zu verlieren.

Alembic installieren

pip install alembic

 

Alembic einrichten

Projekt initialisieren
Im Projektordner:

alembic init alembic

Es entsteht ein Ordner alembic/ + eine Konfigurationsdatei alembic.ini.

 

Konfiguration

  1. In alembic.ini die Datenbank-URL anpassen:

    sqlalchemy.url = sqlite:///./users.db

  2. In alembic/env.py dein Datenbankmodell importieren, z. B.:
    from myapp.database import Base # <- dein Base aus SQLAlchemy
    target_metadata = Base.metadata

So weiß Alembic, welche Tabellen & Modelle existieren.

 

Erste Migration erstellen

alembic revision --autogenerate -m "create users table"

Alembic schaut sich Base.metadata an und erstellt ein Migrationsskript in alembic/versions/…py.

 

Migration ausführen

alembic upgrade head

Die Tabellen werden in der Datenbank erzeugt.

 

Beispiel: Spalte hinzufügen

Angenommen, du ergänzt im SQLAlchemy-Modell eine neue Spalte:

class UserDB(Base):
__tablename__ = "users"
id = Column(Integer, primary_key=True, index=True)
name = Column(String, nullable=False)
email = Column(String, unique=True, index=True, nullable=False)
age = Column(Integer, nullable=True) # <-- NEU

Dann:

  1. Neue Revision erzeugen:
    alembic revision --autogenerate -m "add age column to users"

  2. Migration anwenden:
    alembic upgrade head

Jetzt hat deine Tabelle users eine zusätzliche Spalte age.

 

Best Practices

Immer --autogenerate nutzen, damit Alembic Änderungen automatisch erkennt.
Vor Deployment: Migrationen in einer Testumgebung prüfen.
In Git mit einchecken → Teammitglieder können DB-Schema synchronisieren.
Niemals direkt an der DB-Struktur schrauben – alles über Migrationen.

Widerrufbutton im Onlineshop

Widerrufbutton im Onlineshop

Bei allen B2C Fernabsatzverträgen muss es ab Spätestens ab dem 19. Juni 2026 möglich sein den geschlossenen Vertrag genauso einfach zu widerrufen wie abzuschließen. Was muss ich umbauen? Wie sieht eine Lösung für...

Read more

wasapi modus ausschalten

Um den WASAPI-Exklusivmodus in Windows zu deaktivieren, öffnen Sie über mmsys.cpl (Win+R) die Soundeinstellungen, wählen das Wiedergabegerät aus und entfernen unter „Eigenschaften“ > „Erweitert“ die Haken bei „Anwendungen haben alleinige...

Read more

JCE Fileupload maximum 1024kb

JCE Fileupload maximum 1024kb

Der JCE lässt nur Dateien bis 1024KB ( 1 MB ) zu

Read more

Joomla OSmap Update führt zu Fatal Error…

Joomla OSmap Updates

Die aktuellen Updates von OSMap Free verursachen Fehler bei einem Update.  Problem ist die Erweiterung "ShackExtensionSupport" darin befindet sich die Datei "AbstractScript.php"

Read more

Matomo Cronjob bei ALLinkl einrichten

Matomo (früher Piwik) ist ein Open-Source-Webanalyse-Tool, das ähnlich wie Google Analytics funktioniert, aber mit starkem Fokus auf Datenschutz, Datenhoheit und DSGVO-Konformität.Es kann entweder selbst gehostet (On-Premise) oder als Cloud-Lösung genutzt...

Read more

Unclosed regex pattern at position

Joomshaper Compress JS

Ein unschöner Fehler tritt im Zusammenspiel vom JoomShaper Template „shaper_helixultimate“ und dem Video Plugin „AllVideos (by JoomlaWorks)“ auf.

Read more

Joomla & WordPress-Website lokal/off…

Website lokal speichern mit HTTrack

Ein statisches Backup (HTML Seiten) einer dynamischen Webseite auf CMS Basis (PHP MySQL) wie Wordpress oder Joomla macht sich am besten mit HTTrack. Wir nutzen das Tool gern um einzelne Seiten...

Read more

HTTrack Empty Mirror Error

HTTrack Empty Mirror Error

Wir nutzen den guten alten „WinHTTrack Website Copier“ gern um eine statische Kopie einer Joomla oder Wordpress-Webseite zu erstellen und abzulegen. Das ist vor allem bei Maintenance oder Baustellenseiten eine...

Read more

REST-API : Datenbankmigrationen mit Alem…

Im Zuge der Entwicklung einer REST API mit Python, kommen wir jetzt zu Datenbankmigrationen mit Alembic. Migrationen sind extrem wichtig, wenn du deine Datenbankstruktur im Laufe der Entwicklung ändern willst (z...

Read more
Wir nutzen Cookies auf unserer Website. Diese sind essenziell für den Betrieb der Seite, sogenannte Tracking Cookies werden nicht eingesetzt. Sie können selbst entscheiden, ob Sie die Cookies zulassen möchten. Bitte beachten Sie, dass bei einer Ablehnung womöglich nicht mehr alle Funktionalitäten der Seite zur Verfügung stehen.