INSERT with SELECT

前端 未结 8 1414
灰色年华
灰色年华 2020-11-22 13:49

I have a query that inserts using a select:

INSERT INTO courses (name, location, gid) 
            SELECT name, location, gid 
              FROM courses 
           


        
相关标签:
8条回答
  • 2020-11-22 14:26

    Yes, it is. You can write :

    INSERT INTO courses (name, location, gid) 
    SELECT name, location, 'whatever you want' 
    FROM courses 
    WHERE cid = $ci
    

    or you can get values from another join of the select ...

    0 讨论(0)
  • 2020-11-22 14:26

    I think your INSERT statement is wrong, see correct syntax: http://dev.mysql.com/doc/refman/5.1/en/insert.html

    edit: as Andrew already pointed out...

    0 讨论(0)
  • 2020-11-22 14:30

    Of course you can.

    One thing should be noted however: The INSERT INTO SELECT statement copies data from one table and inserts it into another table AND requires that data types in source and target tables match. If data types from given table columns does not match (i.e. trying to insert VARCHAR into INT, or TINYINT intoINT) the MySQL server will throw an SQL Error (1366).

    So be careful.

    Here is the syntax of the command:

    INSERT INTO table2 (column1, column2, column3)
    SELECT column1, column2, column3 FROM table1
    WHERE condition;
    

    Side note: There is a way to circumvent different column types insertion problem by using casting in your SELECT, for example:

    SELECT CAST('qwerty' AS CHAR CHARACTER SET utf8) COLLATE utf8_bin;
    

    This conversion (CAST() is synonym of CONVERT() ) is very useful if your tables have different character sets on the same table column (which can potentially lead to data loss if not handled properly).

    0 讨论(0)
  • 2020-11-22 14:35

    We all know this works.

    INSERT INTO `TableName`(`col-1`,`col-2`)
    SELECT  `col-1`,`col-2` 
    

    ===========================
    Below method can be used in case of multiple "select" statements. Just for information.

    INSERT INTO `TableName`(`col-1`,`col-2`)
     select 1,2  union all
     select 1,2   union all
     select 1,2 ;
    
    0 讨论(0)
  • 2020-11-22 14:36

    The right Syntax for your query is:

    INSERT INTO courses (name, location, gid) 
    SELECT (name, location, gid) 
    FROM courses 
    WHERE cid = $cid
    
    0 讨论(0)
  • 2020-11-22 14:41

    Sure, what do you want to use for the gid? a static value, PHP var, ...

    A static value of 1234 could be like:

    INSERT INTO courses (name, location, gid)
    SELECT name, location, 1234
    FROM courses
    WHERE cid = $cid
    
    0 讨论(0)
提交回复
热议问题