-
-
Notifications
You must be signed in to change notification settings - Fork 72
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Async function db insert returns ValueError #467
Comments
Emmett's ORM currently doesn't provide async operations support. You get such error because the connection context is not preserved between tasks. Is there any specific reason you want to run such code in an async context? There's no benefit at all vs sync. |
ye i am currently also running async http request which i really don't want to wait for in the main-worker, there are maybe like 20 requests that can take 3-10 seconds each to complete and making the user wait until that is done is kinda not worth it. and whenever a http quests(post quest) is done it will need to do an insert with information about how the request went like: "is_ok", "status_code", "body", "url", ect... |
@gi0baro is there maybe a way i can give the context to the next task as an temporary fix. I have thought about fixing it right now through http request wich is pretty janky(they are signed with jwt btw so i know that i was the one who send it). It would be nice to beable to preserve the context or give the context to a different task. is this an upcomming feature or is it not going to be added? |
@SvenKeimpema if your code runs in a route, the database pipe should work. And you don't even need to call In case your code runs outside of your request flow, you can manually handle the connection in your coroutine, eg: async def my_coro():
await http.get(whatever)
async with db.connection():
db.table.insert(...) Regarding Emmett 3.0: there's not ETA at the moment. To be completely honest, I don't think is gonna happen this year. |
Whenever i do a insert with db.(table).insert in an async function that is managed by asyncio i seem to get an ValueError.
I am not 100% sure why this occurs but i do know this only happend withing the async function run_taak(), see run_taak code.
I tried this without the asyncio and it seemed to be working fine. Is this due to the framework not supporting async db insert's(which would be strange bc even if the insert is async the db should still be able to do it sync)?? Or am i not able to use asyncio for db insert's(if not is there any other lib I can use that supports the same functionality?)
I seem to get an value error
run_taak code:
The text was updated successfully, but these errors were encountered: