表复制某些字段的操作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);
相关推荐
zuoerjinshu5 小时前
sql实战解析-sum()over(partition by xx order by xx)
数据库·sql
NocoBase7 小时前
【2.0 教程】第 1 章:认识 NocoBase ,5 分钟跑起来
数据库·人工智能·开源·github·无代码
Hoshino.418 小时前
基于Linux中的数据库操作——下载与安装(1)
linux·运维·数据库
Oueii9 小时前
Django全栈开发入门:构建一个博客系统
jvm·数据库·python
未来龙皇小蓝10 小时前
【MySQL-索引调优】11:Group by相关概念
数据库·mysql·性能优化
2401_8318249610 小时前
使用Fabric自动化你的部署流程
jvm·数据库·python
njidf10 小时前
Python日志记录(Logging)最佳实践
jvm·数据库·python
twc82910 小时前
大模型生成 QA Pairs 提升 RAG 应用测试效率的实践
服务器·数据库·人工智能·windows·rag·大模型测试
@我漫长的孤独流浪10 小时前
Python编程核心知识点速览
开发语言·数据库·python
2401_8512729910 小时前
实战:用Python分析某电商销售数据
jvm·数据库·python