I have sometimes a problem when running a script. I have the probelm when using an application (that I didn’t write and therefore cannot debug) that launches the scripts. This app isn’t returning the full error from SQL Server, but just the error description, so I don’t know exactly where th error comes.
I have the error only using this tool (it is a tool that sends the queries directly to SQL Server, using a DAC component), if I run the query manuallyin management studio I don’t have the error. (This error moreover occurs only on a particular database).
My query is something like:
SELECT * INTO #TEMP_TABLE
FROM ANOTHER_TABLE
GO
--some other commands here
GO
INSERT INTO SOME_OTHER_TABLE(FIELD1,FIELD2)
SELECT FIELDA, FIELDB
FROM #TEMP_TABLE
GO
DROP TABLE #TEMP_TABLE
GO
The error I get is #TEMP_TABLE is not a valid object
So somehow i suspect that the DROP statement is executed before the INSERT statement.
But AFAIK when a GO is there the next statement is not executed until the previous has been completed.
Now I suspoect that this is not true with temp tables… Or do you have another ideas?
Your problem is most likely caused by either an end of session prior to the
DROP TABLEcausing SQL Server to automatically drop the table or theDROP TABLEis being executed in a different session than the other code (that created and used the temporary table) causing the table not to be visible.I am assuming that stored procedures are not involved here, because it looks like you are just executing batches, since local temporary tables are also dropped when a stored proc is exited.
There is a good description of local temporary table behavior in this article on Temporary Tables in SQL Server: