-
Notifications
You must be signed in to change notification settings - Fork 1k
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
[Draft] Proposal for SQLAlchemy Data Layer with ORM #1365
base: main
Are you sure you want to change the base?
Conversation
…ostgres and others
@qtangs Woop woop! :D :D One important aspect is that we don't break existing applications. Do you think we can reasonably assure that? Or should we deprecate older installations? I expect to review this in the 2nd half of this week. Want to take my time to do it well, as it's such a big one. |
Might want to take this into account #1368 |
@dokterbob I think more testing is needed if we want to replace the old version in-place. I've added a new class to avoid this kind of major impact, anyone needing the new fix can switch to new class in their environment and test accordingly, if something breaks it's easy to switch back to old class. |
We're not gonna support both though, and it seems there's a reasonable user base for the current implementation. I imagine we could deprecate the old version. Or we could use unit tests to somewhat assure consistency. Curious how other community members/users of SQLite/SQLAlchemy reflect on this. |
@dokterbob This would totally be great for my Databricks implementation of this. |
@dokterbob |
This is a proposal for a different way to implement SQLAlchemy Data Layer using ORM instead of raw SQL statements, taking inspiration from #832
Hopefully it will simplify support for other SQL dialects besides Postgres and SQLite.
This is a rather major change:
Other changes:
get_thread
andlist_threads
. only get specific thread(s) for better performance and reduced bandwidth compared toget_all_user_threads
(note: reduced bandwidth is important for providers such as Supabase)list_threads
, filter would use thread name as well as steps input/output texts, this needs careful review.create_element
, storage_provider is made optional so that elements that don't need content to be stored will still be added to database, example of these elements are external links that can be read and displayed at runtime.The diff between current SQLAlchemy and this one can be found here: https://gist.github.com/qtangs/71370e6ce5feec78d9586c808804e81c/revisions?diff=split&w=
Some tests have been added based on https://github.com/Chainlit/chainlit/blob/main/backend/tests/data/test_sql_alchemy.py but more might be needed.