一起插入(选择值)(&A;V) [英] INSERT INTO (SELECT & VALUES) TOGETHER

查看:42
本文介绍了一起插入(选择值)(&A;V)的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在尝试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

这篇关于一起插入(选择值)(&A;V)的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆