一。 把 一个表中的某些字段复制到另一个表中
直接插入值
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);