erikdarlingdata/DarlingData

sp_QuickieStore: Mixing @query_text_search and @query_text_search_not created primary key violations in #query_text_search

ReeceGoding opened this issue · 2 comments

Version of the script
4.5.

What is the current behavior?
When using both @query_text_search and @query_text_search_not, I sometimes get a runtime error reporting primary key violations in #query_text_search . The bad query is allegedly this one.

If the current behavior is a bug, please provide the steps to reproduce.
The trick seems to be to put similar text in both, e.g.
sp_quickiestore @query_text_search = 'username', @query_text_search_not = 'Users'

What is the expected behavior?
No errors to be thrown and for the output to only include queries that match @query_text_search but don't match @query_text_search_not.

Which versions of SQL Server and which OS are affected by this issue? Did this work in previous versions of our procedures?
It's new code.

IMPORTANT: If you're going to contribute code, please read the contributing guide first.
https://github.com/erikdarlingdata/DarlingData/blob/main/CONTRIBUTING.md
Will do.

My general impression from reading the code is that the two parameters simply aren't compatible. They both share the same column of the #query_text_search temp table. I have never made any study of this stored procedure, but it seems obvious that the two parameters won't work together if the list of included queries and the list of excluded queries have both been placed in the same column of the same table.

Perhaps we need to make a #query_text_search_not temp table and EXCEPT-out everything that it shares with the #query_text_search temp table?

@ReeceGoding yeah, this just needs another temp table for the not search. I’ll fix it.