INSERT INTO (SELECT amp; VALUES) TOGETHER(一起插入(选择值)(A;V))
本文介绍了一起插入(选择值)(&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_name
和last_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)的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
织梦狗教程
本文标题为:一起插入(选择值)(&A;V)


基础教程推荐
猜你喜欢
- 如何根据该 XML 中的值更新 SQL 中的 XML 2021-01-01
- 在 MySQL 中:如何将表名作为存储过程和/或函数参数传递? 2021-01-01
- 表 './mysql/proc' 被标记为崩溃,应该修复 2022-01-01
- 在多列上分布任意行 2021-01-01
- 二进制文件到 SQL 数据库 Apache Camel 2021-01-01
- oracle区分大小写的原因? 2021-01-01
- MySQL 中的类型:BigInt(20) 与 Int(20) 2021-01-01
- mysql选择动态行值作为列名,另一列作为值 2021-01-01
- 如何在 SQL 中将 Float 转换为 Varchar 2021-01-01
- 什么是 orradiag_<user>文件夹? 2022-01-01