Comments (2)
Would PR #43 solve this when merged?
from sqlmodel.
I was able to achieve this with the below workaround.
class UserActivityBase(SQLModel):
# One table per user
# Created first time when a user logs in perhaps
created_ts: datetime.datetime = Field(primary_key=True)
activity_type: str
activity_value: float
async def create_user_activity_model(uuid: str, engine: AsyncEngine):
class UserActivity(UserActivityBase, table=True):
__tablename__ = 'user_activity_' + uuid
__table_args__ = {'schema': 'user_schema',
'keep_existing': True}
# Create the table if needed
async with engine.begin() as conn:
await conn.run_sync(SQLModel.metadata.create_all)
return UserActivity
class UserActivityCrud(UserActivityBase):
pass
async def get_user_activity_model(uuid: str):
class UserActivityCrud(UserActivityBase, table=True):
__tablename__ = 'user_activity_' + uuid
__table_args__ = {'schema': 'user_schema',
'keep_existing': True}
return UserActivityCrud
UserActivityBase
is the base SQLModel. When you want to create the table for a new user, you can call create_user_activity_model()
with the user's uuid
and the engine
instance. Later, when you need to get the model for a particular user, just call get_user_activity_model(uuid=<uuid>)
.
The only thing I am facing is a warning. When you call get_user_activity_model
more than once, the below warning is thrown.
/Users/ghanti/code/proj/venv/lib/python3.9/site-packages/sqlmodel/main.py:367: SAWarning: This declarative base already contains a class with the same class name and module name as app.models.UserActivityCrud, and will be replaced in the string-lookup table.
I feel this can be ignored. @tiangolo can you please confirm?
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.