2026-01-06 16:47:18 +00:00
|
|
|
import os
|
|
|
|
|
|
2025-11-23 09:08:01 +00:00
|
|
|
from sqlmodel import Session, SQLModel, create_engine # type: ignore
|
|
|
|
|
|
2026-01-06 16:47:18 +00:00
|
|
|
DATABASE_URL = os.getenv("DATABASE_URL", "sqlite:///./notes.db")
|
|
|
|
|
|
|
|
|
|
# Only use check_same_thread for SQLite
|
|
|
|
|
connect_args = {"check_same_thread": False} if DATABASE_URL.startswith("sqlite") else {}
|
2025-11-23 09:08:01 +00:00
|
|
|
|
2026-01-06 16:47:18 +00:00
|
|
|
engine = create_engine(DATABASE_URL, echo=True, connect_args=connect_args)
|
2025-11-23 09:08:01 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
def create_db_and_tables():
|
|
|
|
|
SQLModel.metadata.create_all(engine)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def get_session():
|
|
|
|
|
with Session(engine) as session:
|
|
|
|
|
yield session
|