Files
LibraryAPI/app/models.py
2025-05-27 13:09:50 +03:00

22 lines
768 B
Python

from typing import List
from sqlmodel import SQLModel, Field, Relationship
# Relationship model
class AuthorBookLink(SQLModel, table=True):
author_id: int | None = Field(default=None, foreign_key="author.id", primary_key=True)
book_id: int | None = Field(default=None, foreign_key="book.id", primary_key=True)
# Author model
class Author(SQLModel, table=True):
id: int | None = Field(primary_key=True, index=True)
name: str
books: List["Book"] = Relationship(back_populates="authors", link_model=AuthorBookLink)
# Book model
class Book(SQLModel, table=True):
id: int | None = Field(primary_key=True, index=True)
title: str
description: str
authors: List[Author] = Relationship(back_populates="books", link_model=AuthorBookLink)