-
-
Notifications
You must be signed in to change notification settings - Fork 398
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
Make transaction work with async callbacks. #1262
Comments
This has already been discussed and the decision made not to provide such support in: |
@winghouchan Your kidding right?. I'm fully aware of the issues of keeping transactions short, this is the case for any ACID db. Lets take another example, let's say you had records, eg. like Invoices and you wanted to clone from 1 DB to another, maybe Posgress etc. You have to make sure during each copy of an Invoice that both DB have a lock while copying (Invoice / lines) etc. Using your transaction, this is not possible, because the other DB uses Of course I can get around this by just manually using my own transaction and avoid yours,. But really?, the mod I proposed has Zero effect on |
Nobody is kidding here. By using async operations within a SQLite transaction, you're locking your entire database for a long time, ruining the performance of anything else that might be going on in your application (e.g., other requests being handled concurrently). Therefore, 99% of the time, it's better to do the necessary async operations before the transaction, if possible. Most people are not experts in this stuff, so I designed the API of |
I know how transactions work, anyway it's your project, and it kind of breaks Drizzle integration as it kind of assumes |
@KpjComp to be fair when this project was created almost no one was using sqlite for servers. This practice only started with turso and cloudflare d1 so yes when you're doing an API where you expect more than 10 simultaneous users at once hitting the API, you should use @libsql/client by all means |
@capaj Yeah, no problem. The conversion took seconds as Drizzle handles the rest, and the bonus for me it's seems faster, as the Server can now breath. (very important). One bit of advice on the NPM docs it say's "When is this library not appropriate?", maybe when used in a server environment, as blocking the event loop is a bad idea, even if the queries are only short. Maybe better-sqlite3 shines for batch console utilities etc. |
Well, if you get in trouble, because your transactions / statements keep locking up the event loop, switching to asynchronous code may seem as "the solution", but to me this looks more like a cover up. SQLite3 is fast by nature. And if your tables are fine, your indices are well defined and you know your SQL, it stays fast even wrapped into a NodeJS context. But if you adding more and more layers (or frameworks) that take these things away from you .. well.. it's not a single library to blame. I can understand that you might not be satisfied with the result of your initial request, but I cannot understand, why you are trying to run down better-sqlite3 just because you could not solve your issues. Now stating this lib might only "shine" in console utilities is just shows some lack of understanding. Might be, that it's not the best to be used within a web server with a high amount of concurrent requests - but maybe SQLite per se and NodeJS are not the best picks here, if things like data migrations are triggered by a simple request. If you are really doing blocking actions, like reading files or waiting for responses from another server, while holding an expensive resource like a database connection / transaction, there is the issue. No matter in which environment. This is bad design. Especially if the database is SQLite3, which will eventually lock the whole database on certain operations anyway and force somewhat of blocking, serialized operations. |
Again I know how ACID works, and the risks of keep transactions open for a long period, just because something is The server environment problem is rather simple, the blocking nature of better-sqlite3 is fine for sync projects, but by definition a Server is not. Even a short SQLite query blocking the event loop for 100ms is a performance hit for a Server. Of course you can mitigate this by spawning a workers but was overkill for my use case. And moving to why you are trying to run down better-sqlite3 I think the project is a good project, and I'm sure it has use cases that it shines in, eg. where the event loop is not a big issue. I suppose I got a bit miffed, because I spent time tracking down the issue I was having, there was no error to indicate transactions were failing, apart from looking at the data. Maybe a check on the callback to make sure it's not a Promise would have helped here. Maybe a |
Came across this problem when using Drizzle, and found transactions were not actually rolling back.
The issue is that
wrapTransaction
always assumes the callback issync
, in this day of JS that's often not going to be the case, eg. during the transaction you might want to read a file, make a http request etc, without using blocking methods.One solution is check if the result is a Promise, if use
then
&fail
to handle the commit / rollback. This should then meansync
requests continue as is, and Promise version is then correctly handled too.eg.
The text was updated successfully, but these errors were encountered: