一起插入(选择值)(&A;V)

2022-04-05 00:00:00 sql insert-into mysql

我正在尝试INSERT INTO一个表,我知道两种方法:

将行作为值添加:

INSERT INTO db_example.tab_example (id,name,surname,group)
VALUES ('','Tom','Hanks','1');

或来自另一个表:

INSERT INTO db_example.tab_example (id,name,surname)
SELECT ID,first_name,last_name FROM db_contacts.tab_mygroup;

但是,如果我想要插入另一个表中的某些值(第二种方法),而某些值手动类似于缺省值(第一种方法),该怎么办?

这是我的尝试(不起作用):

INSERT INTO db_example.tab_example (id,name,surname,group)
VALUES (
 SELECT ID FROM db_contacts.tab_mygroup,
 SELECT first_name FROM db_contacts.tab_mygroup,
 SELECT last_name FROM db_contacts.tab_mygroup,
 '1'
);

我想创建一个VIEW表,它可能会解决问题,但我想可能会有某种方法将两者加在一起。

谢谢你们!我希望我已经很好地描述了我所需要的:)


解决方案

只返回SELECT语句的文字值;向SELECT列表添加一个表达式。例如:

INSERT INTO db_example.tab_example (id,name,surname,group)
SELECT ID
     , first_name
     , last_name
     , '1' AS group
  FROM db_contacts.tab_mygroup;

后续

q:是否可以使用As函数在同一列中选择First_Name和Last_Name?或者我需要其他函数?

A:如果要将first_namelast_name中的值合并为一列,可以使用表达式将它们连接起来,并在选择列表中使用该表达式,例如

CONCAT(last_name,', ',first_name')

CONCAT(first_name,' ',last_name)

AS关键字在INSERT ... SELECT的上下文中不会有任何效果,但是为该表达式分配一个与要插入该表达式的列的名称匹配的别名确实有助于将来的读者。

INSERT INTO db_example.tab_example (id,name,surname,group,full_name)
SELECT ID
     , first_name
     , last_name
     , '1' AS group
     , CONCAT(first_name,' ',last_name) AS full_name
  FROM db_contacts.tab_mygroup

相关文章