I have some sprocs that need a temp table. In order not to hardcode the column types (which are varchar with some length) so I don't have to change the declarations when the reference table schema changes (i.e. fields become longer) I do this (instead of a create table call):
select orderId
into #sometmptbl
from orders
where 1=2
However, when you do a showplan on this it actually seems to be going to the table/index:
QUERY PLAN FOR STATEMENT 1 (at line 1).
STEP 1 The type of query is CREATE TABLE. STEP 2 The type of query is INSERT. The update mode is direct. FROM TABLE orders Nested iteration. Index : orders_idx1 Forward scan. Positioning at index start. Index contains all needed columns. Base table will not be read. Using I/O Size 2 Kbytes for index leaf pages. With LRU Buffer Replacement Strategy for index leaf pages. TO TABLE #sometmptbl Using I/O Size 2 Kbytes for data pages.
Total estimated I/O cost for statement 1 (at line 1): 632082.
Does this mean 1=2 gets evaluated for every entry in the index? Is there a way to do this in a constant time?
Update:
Here's the actual I/O cost after the execute so it looks like the actual reads are indeed 0 so there's no performance impact:
Table: orders scan count 0, logical reads: (regular=0 apf=0 total=0), physical reads: (regular=0 apf=0 total=0), apf IOs used=0
Table: #sometmptbl_____00002860018595346 scan count 0, logical reads: (regular=1 apf=0 total=1), physical reads: (regular=0 apf=0 total=0), apf IOs used=0
Total actual I/O cost for this command: 2.
Total writes for this command: 3
0 row(s) affected.