Comments (7)
I also encountered this issue and ended up implementing the check for a Literal at the beginning of get_sqlachemy_type
.
field_type = field.type_
if is_literal_type(field_type):
# Try to get the single type of the literal, error otherwise
types = list({type(x) for x in get_args(field_type)})
if len(types) != 1:
raise RuntimeError("Cannot map a literal with multiple types to a sql type.")
field_type = types[0]
To make this work you would still need to import get_args
and is_literal_type
, also refactor each field.type_
call to field_type
The problem with this solution is that it is specifically for a Literal. So, not sure if this will be immediately accepted to be implemented. Happy to make this into a PR if needed.
I eventually stopped using Literal, and chose for an Enum, which works out of the box :)
In your case:
from enum import Enum
class NameEnum(str, Enum):
FASTAPI = "fastapi"
SQLMODEL = "sqlmodel"
class Cool(SQLModel, table=True):
name: NameEnum
from sqlmodel.
@shifqu this solved my problem, thanks!
from sqlmodel.
EDIT: See pydantic/pydantic#5821 (comment) for the main issue and a list of workarounds.
I'm deleting the rest of my comment: all its information is present in the linked thread.
from sqlmodel.
I have the same issue and went with the enum solution. But the Literal
approach would be still worth adding I guess, for the future to open up the possibilities.
from sqlmodel.
I encountered an issue with the enum approach (see #406) where the validation for the field with the enum values silently passes for invalid values.
from sqlmodel.
I have this issue when trying to use a Discriminated Union on a SQLModel a la Pydantic
from sqlmodel.
In your case:
from enum import Enum class NameEnum(str, Enum): FASTAPI = "fastapi" SQLMODEL = "sqlmodel" class Cool(SQLModel, table=True): name: NameEnum
I have to emphasis this code actually write FASTAPI
uppercase, the enum key into database, not "fastapi"
lower case, the value.
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.