表复制某些字段的操作sql

一。 把 一个表中的某些字段复制到另一个表中

直接插入值

复制代码
INSERT INTO 表名 (列1, 列2, 列3, ...)
VALUES (值1, 值2, 值3, ...);

表之间的插入

复制代码
insert into sys_user_permission(userId,nickName,status)
select userId,nickname,status from sys_user
where not exists(
	select 1 from sys_user_permission p
	where p.userId = sys_user.userId
);

where后面的意思是,当两个表经过筛选后,只插入第一条。也就是userId唯一

二、在一的基础上,我发现漏了一个字段,我想复制deptId字段

1.更新不插入新纪录

复制代码
update p set p.deptId = u.deptId from sys_user_permission p
join sys_user u on p.userId = u.userId


JOIN 的原因是:让数据库"把两张表按某个条件拼到一起",这样才能拿到另一张表的字段值来
把 sys_user 和 sys_user_permission 按 userId 拼在一起,这样我就能用 sys_user.deptId 去更新 sys_user_permission.deptId。

2.更新并插入新纪录

复制代码
MERGE sys_user_permission AS target
USING sys_user AS src
ON target.userId = src.userId

WHEN MATCHED THEN
    UPDATE SET
        target.deptId   = src.deptId,
        target.nickname = src.nickname

WHEN NOT MATCHED THEN
    INSERT (userId, nickname, deptId)
    VALUES (src.userId, src.nickname, src.deptId);
相关推荐
野犬寒鸦1 天前
今日面试之项目拷打:锁与事务的深度解析
java·服务器·数据库·后端
阿沁QWQ1 天前
使用c语言连接数据库
数据库
奥尔特星云大使1 天前
mysql重置管理员密码
linux·运维·数据库·mysql·centos
Lbwnb丶1 天前
p6spy 打印完整sql
java·数据库·sql
奥尔特星云大使1 天前
MySQL多实例管理
linux·运维·数据库·mysql·dba·mysql多实例
ヾChen1 天前
初识MySQL
数据库·物联网·学习·mysql
牛奶咖啡131 天前
高可用MySQL的整体解决方案、体系化原理和指导思路
数据库·mysql·主从复制·高可用mysql解决方案·双主复制·mha高可用·全同步和半同步复制
wow_DG1 天前
【MySQL✨】MySQL 入门之旅 · 第十一篇:常见错误排查与解决方案
数据库·mysql·adb
博睿谷IT99_1 天前
GaussDB 和 openGauss 怎么区分?
数据库·华为认证·opengauss·it·gaussdb
野犬寒鸦1 天前
今日面试之快问快答:Redis篇
java·数据库·redis·后端·缓存·面试·职场和发展