Why does the syntax work for insert and not insert into?

  • Given that someone, before me, used the wrong table name... this.that, could someone please tell me why the syntax is not working for both INSERT and INSERT INTO?

    insert [this.that].dbo.table_name

    insert into [this.that].dbo.table_name

    The insert fails.. due to too many parts... it shows "this.that.dbo.table_name" not what whas typed in "[this.that].dbo.table_name".

  • INSERT and INSERT INTO are identical - INTO is there only as a readability aid.

    The absence of evidence is not evidence of absence.
    Martin Rees

    You can lead a horse to water, but a pencil must be lead.
    Stan Laurel

  • dwilliscp (7/16/2012)


    Given that someone, before me, used the wrong table name... this.that, could someone please tell me why the syntax is not working for both INSERT and INSERT INTO?

    insert [this.that].dbo.table_name

    insert into [this.that].dbo.table_name

    The insert fails.. due to too many parts... it shows "this.that.dbo.table_name" not what whas typed in "[this.that].dbo.table_name".

    Opps sorry.. been working with this code too long today.. the question SHOULD have read..

    Given that someone, before me, used the wrong table name... this.that, could someone please tell me why the syntax is not working for both INTO and INSERT INTO?

    select *

    into [this.that].dbo.table_name

    from #a

    insert into [this.that].dbo.table_name

    Select *

    from #a

    The insert fails.. due to too many parts... it shows "this.that.dbo.table_name" not what whas typed in "[this.that].dbo.table_name".

  • both commands will work perfectly in SSMS;

    are you running this through an ODBC driver, and the driver might be mis-translating the object names?

    where is this code being executed?

    Lowell


    --help us help you! If you post a question, make sure you include a CREATE TABLE... statement and INSERT INTO... statement into that table to give the volunteers here representative data. with your description of the problem, we can provide a tested, verifiable solution to your question! asking the question the right way gets you a tested answer the fastest way possible!

  • dwilliscp (7/16/2012)

    The insert fails.. due to too many parts... it shows "this.that.dbo.table_name" not what whas typed in "[this.that].dbo.table_name".

    It's hard to know if you don't give the exact error, code and/or DDL.

    Luis C.
    General Disclaimer:
    Are you seriously taking the advice and code from someone from the internet without testing it? Do you at least understand it? Or can it easily kill your server?

    How to post data/code on a forum to get the best help: Option 1 / Option 2
  • Lowell (7/16/2012)


    both commands will work perfectly in SSMS;

    are you running this through an ODBC driver, and the driver might be mis-translating the object names?

    where is this code being executed?

    I created a database [this.that] and could not get the INSERT statement to work.

  • Lynn Pettis (7/16/2012)


    Lowell (7/16/2012)


    both commands will work perfectly in SSMS;

    are you running this through an ODBC driver, and the driver might be mis-translating the object names?

    where is this code being executed?

    I created a database [this.that] and could not get the INSERT statement to work.

    with this code, i tested it on 2008 and 2005 with not errors..., not sure what the OP is doing specifically.

    create database [this.that]

    GO

    use [this.that]

    select top 5 * into #a from sys.columns

    select *

    into [this.that].dbo.table_name

    from #a

    insert into [this.that].dbo.table_name

    Select *

    from #a

    select * FROM [this.that].dbo.table_name

    GO

    use master

    drop database [this.that]

    Lowell


    --help us help you! If you post a question, make sure you include a CREATE TABLE... statement and INSERT INTO... statement into that table to give the volunteers here representative data. with your description of the problem, we can provide a tested, verifiable solution to your question! asking the question the right way gets you a tested answer the fastest way possible!

  • I had no errors whatsoever with the database name of this.that

    see below example

    Create database [this.that];

    GO

    Use [this.that];

    GO

    Create table [this.that] (someid int);

    GO

    with E1(N) AS (

    SELECT 1 UNION ALL SELECT 1 UNION ALL SELECT 1 UNION ALL

    SELECT 1 UNION ALL SELECT 1 UNION ALL SELECT 1 UNION ALL

    SELECT 1 UNION ALL SELECT 1 UNION ALL SELECT 1 UNION ALL SELECT 1

    ), --10E+1 or 10 rows

    E2(N) AS (SELECT 1 FROM E1 a, E1 b), --10E+2 or 100 rows

    E4(N) AS (SELECT 1 FROM E2 a, E2 b)

    Insert Into [this.that].dbo.sometable (someid)

    Select N

    From E4;

    Truncate Table sometable;

    with E1(N) AS (

    SELECT 1 UNION ALL SELECT 1 UNION ALL SELECT 1 UNION ALL

    SELECT 1 UNION ALL SELECT 1 UNION ALL SELECT 1 UNION ALL

    SELECT 1 UNION ALL SELECT 1 UNION ALL SELECT 1 UNION ALL SELECT 1

    ), --10E+1 or 10 rows

    E2(N) AS (SELECT 1 FROM E1 a, E1 b), --10E+2 or 100 rows

    E4(N) AS (SELECT 1 FROM E2 a, E2 b)

    Insert [this.that].dbo.sometable (someid)

    Select N

    From E4;

    Truncate table sometable;

    Jason...AKA CirqueDeSQLeil
    _______________________________________________
    I have given a name to my pain...MCM SQL Server, MVP
    SQL RNNR
    Posting Performance Based Questions - Gail Shaw[/url]
    Learn Extended Events

  • Lowell (7/16/2012)


    Lynn Pettis (7/16/2012)


    Lowell (7/16/2012)


    both commands will work perfectly in SSMS;

    are you running this through an ODBC driver, and the driver might be mis-translating the object names?

    where is this code being executed?

    I created a database [this.that] and could not get the INSERT statement to work.

    with this code, i tested it on 2008 and 2005 with not errors..., not sure what the OP is doing specifically.

    create database [this.that]

    GO

    use [this.that]

    select top 5 * into #a from sys.columns

    select *

    into [this.that].dbo.table_name

    from #a

    insert into [this.that].dbo.table_name

    Select *

    from #a

    select * FROM [this.that].dbo.table_name

    GO

    use master

    drop database [this.that]

    All right, add me to the list of confused. I ran your code above with no problems on SQL Server 2008 R2.

  • Select ... Into ... is VERY different from Insert ... Select ...

    The Select Into syntax will create the target table. If it already exists, you'll get an error message. The Insert Select syntax inserts into a table that already exists. If it doesn't exist yet, you'll get an error message.

    They aren't equivalent statements.

    You can run them in sequence Select Into then Insert Select, because the Select Into will create the table and the Insert Select will insert into it. But you can't do it the other way around, Insert Select then Select Into won't work, because the table doesn't exist yet when the Insert Select is run.

    That looks like the most likely real error here. Nothing to do with the database name.

    - Gus "GSquared", RSVP, OODA, MAP, NMVP, FAQ, SAT, SQL, DNA, RNA, UOI, IOU, AM, PM, AD, BC, BCE, USA, UN, CF, ROFL, LOL, ETC
    Property of The Thread

    "Nobody knows the age of the human race, but everyone agrees it's old enough to know better." - Anon

  • GSquared (7/16/2012)


    Select ... Into ... is VERY different from Insert ... Select ...

    The Select Into syntax will create the target table. If it already exists, you'll get an error message. The Insert Select syntax inserts into a table that already exists. If it doesn't exist yet, you'll get an error message.

    They aren't equivalent statements.

    You can run them in sequence Select Into then Insert Select, because the Select Into will create the table and the Insert Select will insert into it. But you can't do it the other way around, Insert Select then Select Into won't work, because the table doesn't exist yet when the Insert Select is run.

    That looks like the most likely real error here. Nothing to do with the database name.

    I'm not going to look at further, but what didn't work for me was create the database, create the table, complete an insert into. The insert into failed with the same error the OP is reporting.

    I run the code Lowell posted, and everything worked just great.

    See, I'm confused.

  • ok i think i see it.

    if you run my previous sample code, including the DROP DATABASE,a dn THEN run the code snippets below, you get a misleading message:

    it's not maintaining the quotename around the database object into the error message.

    Msg 208, Level 16, State 1, Line 2

    Invalid object name 'this.that.dbo.table_name'.

    insert into [this.that].dbo.table_name

    Select *

    from #a

    select * FROM [this.that].dbo.table_name

    Lowell


    --help us help you! If you post a question, make sure you include a CREATE TABLE... statement and INSERT INTO... statement into that table to give the volunteers here representative data. with your description of the problem, we can provide a tested, verifiable solution to your question! asking the question the right way gets you a tested answer the fastest way possible!

  • Lynn Pettis (7/16/2012)


    GSquared (7/16/2012)


    Select ... Into ... is VERY different from Insert ... Select ...

    The Select Into syntax will create the target table. If it already exists, you'll get an error message. The Insert Select syntax inserts into a table that already exists. If it doesn't exist yet, you'll get an error message.

    They aren't equivalent statements.

    You can run them in sequence Select Into then Insert Select, because the Select Into will create the table and the Insert Select will insert into it. But you can't do it the other way around, Insert Select then Select Into won't work, because the table doesn't exist yet when the Insert Select is run.

    That looks like the most likely real error here. Nothing to do with the database name.

    I'm not going to look at further, but what didn't work for me was create the database, create the table, complete an insert into. The insert into failed with the same error the OP is reporting.

    I run the code Lowell posted, and everything worked just great.

    See, I'm confused.

    I'd have to see your exact script, the one that's failing, to pinpoint the problem.

    The error message drops the [] around the database name, but that doesn't matter. What matters is if they're in the script, not whether they're in the error message.

    - Gus "GSquared", RSVP, OODA, MAP, NMVP, FAQ, SAT, SQL, DNA, RNA, UOI, IOU, AM, PM, AD, BC, BCE, USA, UN, CF, ROFL, LOL, ETC
    Property of The Thread

    "Nobody knows the age of the human race, but everyone agrees it's old enough to know better." - Anon

  • Ok.. I thought maybe I was missing something simple, sorry.

    here is the error message..

    Msg 117, Level 15, State 1, Line 3

    The object name 'R2D2.this.that.dbo.ztb_test' contains more than the maximum number of prefixes. The maximum is 2.

    and the SQL

    select top 5 *

    into R2D2.[this.that].dbo.ztb_test

    from zt_sysjobs

    I am using 2005 SQL Server management Studio.. this error is the same as a Stored Proc as it is in a query window.

  • Have you tried this?

    select top 5 *

    into [this.that].dbo.ztb_test

    from zt_sysjobs

    Luis C.
    General Disclaimer:
    Are you seriously taking the advice and code from someone from the internet without testing it? Do you at least understand it? Or can it easily kill your server?

    How to post data/code on a forum to get the best help: Option 1 / Option 2

Viewing 15 posts - 1 through 15 (of 20 total)

You must be logged in to reply to this topic. Login to reply