INSERT INTO vs SELECT INTO
What is the difference between using
SELECT ... INTO MyTable FROM...
and
INSERT INTO MyTable (...)
SELECT ... FROM ....
?
From BOL [ INSERT, SELECT...INTO ], I know that using SELECT...INTO will create the insertion table on the default file group if it doesn't already exist, and that the logging for this statement depends on the recovery model of the database.
- Which statement is preferable?
- Are there other performance implications?
- What is a good use case for SELECT...INTO over INSERT INTO ...?
Edit: I already stated that I know that that SELECT INTO... creates a table where it doesn't exist. What I want to know is that SQL includes this statement for a reason, what is it? Is it doing something different behind the scenes for inserting rows, or is it just syntactic sugar on top of a CREATE TABLEand INSERT INTO.
- They do different things. Use
INSERTwhen the table exists. UseSELECT INTOwhen it does not. - Yes.
INSERTwith no table hints is normally logged.SELECT INTOis minimally logged assuming proper trace flags are set. - In my experience
SELECT INTOis most commonly used with intermediate data sets, like#temptables, or to copy out an entire table like for a backup.INSERT INTOis used when you insert into an existing table with a known structure.

浙公网安备 33010602011771号