-
Notifications
You must be signed in to change notification settings - Fork 248
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
Getting parameterised query text without placeholders #902
Comments
Alas, I don't know if any way to get that version of the query string. I guess it would be possible to reconstruct it, but that can go wrong in exactly the kind of situation where you need it most. |
I suppose the main problem is that postgres itself doesn't always log parameters, so we have to rely on either the library, or the application to remember them. |
Text is no longer simple. :-( Yes, it can be done, but it's starting to sound like work. Imagine you're working in an encoding like SJIS. Your parameters look like Or consider the complexity of support for complex data types — support that may live in your application rather than in libpqxx itself. I'm not sure the quoting and escaping rules will always be appropriate. Will libpqxx need to figure out the parameters' SQL types? How do we keep those choices consistent with libpq's? And how do we represent binary? In theory it's all doable. But it does add complexity and scope for error, and error handling is the worst place for that. What might work better is to show the query as-is, and then also make the parameter values available. However I do kind of hate to leave that responsibility on your shoulders because it exposes your application to encoding issues. For instance, you might be running on Windows in UTF-16, but with UTF-8 as your postgres client encding — that probably means you can't just print these values. And you may want to truncate long parameter values for display, but you'll need to take care not to truncate in the middle of a character. (And then in some languages, there are places where truncating between characters doesn't make sense in some cases, but that's a minor thing so let's not even get into that.) In short: I hate parsing text in dynamically determined encodings. :-) |
Looking at this again now, it all seems a bit less dramatic. What we can probably do is leave the query text as-is, but append some text describing the parameters. In fact I think that would be even more helpful. The other thing though is that I don't know when I might get around to this. I'm finally doing serious work on libpqxx 8.0, which will have much more far-reaching consequences for exceptions. So it may be quite some time. I'll keep the ticket open. |
Is there a way to know the proper text of the executed query, with placeholder text replaced with bound parameters? Relevant for exception handling and logging purposes, where you might not know the parameters used, but need information the most.
Right now there is a weird pattern for more complicated queries. It's better to format query-strings with escaped parameters in the application itself, "on your own", and only then execute the resulting statement with no parameters.
The text was updated successfully, but these errors were encountered: