-
Notifications
You must be signed in to change notification settings - Fork 468
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
feature: add hints to errors when returning errors from the server #983
Comments
I think this is a good idea, however the error is most likely coming from the tedious driver as it's the one parsing the TDS stream, this library just wraps it. It may be better to bring this up on the tedious repo instead? |
The error comes from the server when it tries to parse the sent data stream. (So the server fails to parse not the tedious driver.)
I would not expect a low level driver to make guesses what happened as it has no context about the desired operation, I would expect that from the higher level abstractions (like this library). For example: This error is only affected when bulk inserting data. (single insert via request works with wrong data type specified). The driver itself doesn't know we are trying to bulk insert it just parses and sends the received data. However (I assume) the library is aware that we are bulk inserting when the error is received so it can show tips based on desired operation. |
I see what you're saying, but the drivers also know when a bulk operation is happening because they expose this. However, because we are providing a common interface for more than one driver, it probably would be less effort for us to implement this than pushing the responsibility onto 2 (or more) drivers. @NoNameProvided is this something you'd be willing to contribute to the library? |
Hi! Sorry for the late reply. I am not sure I have the all around expertise to "discover" all the possible edge-cases. (Read as I am a very basic user or MSSQL, we only develop in it for a customer, we use Postgres otherwise.) If you like to I can write a note section about this in the bulk insert part of the documentation or if we discuss the proposed way to handle this from code, I am down to contribute. |
I don't think we need to discover all the edge cases - just filling them in as we come across them is fine |
What is your opinion should we add this as documentation or included it in the code? I see four options here:
The first two I don't like personally as it changes the original error what is not desirable. The 3rd option can work but polluting the global console without allowing the user to disable it is a no-go, so some minimal log handler must be added for it which the user can enable/disable. (If we go this direction it can be combined with #840 to remove the dependency on the debug The fourth option is the simplest but requires the user to search for the issue instead of being presented on the spot. |
I have tried to create a bulk insert and struggled more hours than I willing to admit to understand why I am receiving the following error on every attempt:
This is a very general error message (from the MS SQL server) and doesn't include any details why the data stream is invalid. After searching the issues here and after Googling I still couldn't find any discussion about it besides some irrelevant Microsoft knowledgebase articles.
The root of the problem was that one of the inserted fields used an
Text
type instead ofChar(7)
.Expected behaviour:
I am sure I am not the first one to run into this issue. I would have expected that the error message contains hints about what can go wrong when this messages is received.
I would either expect some direct hints inlined in the error or a link directing me to a FAQ page where the common problems are listed.
Actual behaviour:
No hints are provided why this error is happening.
Configuration:
Code re reproduce
Software versions
The text was updated successfully, but these errors were encountered: