Comments (3)
Try this out
from datetime import datetime
from typing import Optional
from pydantic import BaseModel
from sqlmodel import SQLModel, Column, DateTime, Field, Session, create_engine, select
class TimeStampMixin(BaseModel):
created_at: Optional[datetime] = Field(
sa_column=Column(
DateTime,
default=datetime.utcnow,
nullable=False,
)
)
updated_at: Optional[datetime] = Field(
sa_column=Column(
DateTime,
default=datetime.utcnow,
onupdate=datetime.utcnow,
)
)
class MyModel(SQLModel, TimeStampMixin, table=True):
id: Optional[int] = Field(default=None, primary_key=True)
name: str
engine = create_engine("sqlite:///database.db")
SQLModel.metadata.create_all(engine)
with Session(bind=engine) as session:
session.add(MyModel(name="A Name"))
session.commit()
from sqlmodel.
Why do we need to extend the Mixins from pydantic BaseModel and not SQLModel? Or is both possible? Also, with SQLModel, the definition would be simpler:
class TimeStampMixin(SQLModel):
created_at: Optional[datetime] = Field(default=datetime.utcnow(), nullable=False)
updated_at: Optional[datetime] = Field(default_factory=datetime.utcnow, nullable=False)
from sqlmodel.
Try this out
from datetime import datetime from typing import Optional from pydantic import BaseModel from sqlmodel import SQLModel, Column, DateTime, Field, Session, create_engine, select class TimeStampMixin(BaseModel): created_at: Optional[datetime] = Field( sa_column=Column( DateTime, default=datetime.utcnow, nullable=False, ) ) updated_at: Optional[datetime] = Field( sa_column=Column( DateTime, default=datetime.utcnow, onupdate=datetime.utcnow, ) ) class MyModel(SQLModel, TimeStampMixin, table=True): id: Optional[int] = Field(default=None, primary_key=True) name: str engine = create_engine("sqlite:///database.db") SQLModel.metadata.create_all(engine) with Session(bind=engine) as session: session.add(MyModel(name="A Name")) session.commit()
That works! This also enables a Generic[_T]
base class
from sqlmodel.
Related Issues (20)
- There is no unique constraint matching given keys (one-to-many, connecting with many-to-many tables) HOT 2
- Preparing for Pydantic v2 release HOT 13
- Data Integrity: Raise error on attempt to delete an object required via a Relationship HOT 8
- [Querying] negating `Model.boolean` in `where()` HOT 2
- [M2M] Query dependent incl. `link_model` fields HOT 3
- Could not refresh instance HOT 9
- SQLModel doesn't recognize Relationship between models HOT 1
- Get select with options (selectinload) using response schema HOT 2
- Dose there any better way to write timezone aware datetime field without using the SQLAlchemy ? HOT 3
- Obtaining `TypeError: Cannot pickle 'module' object` on models with many-to-many relationships HOT 2
- Order of columns in the table created does not have 'id' first, despite the order in the SQLModel. Looks like it's prioritising fields with sa_column HOT 3
- Erro ao executar uvicorn.run(...) HOT 1
- Many to many relationship between a table and itself HOT 6
- How to add current date time by default on a table declaration? HOT 13
- Add documentation about how to use the async tools (session, etc) HOT 5
- async relationship bug HOT 9
- 🚀 Roadmap HOT 28
- Internal link failed at create-db-and-table.md
- Field cannot autocompletion when its a SQLModel HOT 6
- Add an overload to the `exec` method with `_Executable` statement for update and delete statements
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from sqlmodel.