Source code for geochemistrypi.database
import os
from dotenv import load_dotenv
from sqlalchemy import create_engine
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import sessionmaker
# Load the .env file
load_dotenv()
# Get the database URL from the environment
database_url = os.getenv("SQLALCHEMY_DATABASE_URL")
# Create the database engine
engine = create_engine(database_url, connect_args={"check_same_thread": False})
# Create a sessionmaker
SessionLocal = sessionmaker(autocommit=False, autoflush=False, bind=engine)
# Create a base class for the models
Base = declarative_base()
[docs]
def get_db():
"""Get a database session."""
db = SessionLocal()
try:
yield db
finally:
db.close()