表复制某些字段的操作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);
相关推荐
weixin_580614001 小时前
如何提取SQL日期中的年份_使用YEAR或EXTRACT函数
jvm·数据库·python
2301_813599551 小时前
SQL生产环境规范_数据库使用最佳实践
jvm·数据库·python
a9511416421 小时前
Go 中通过 channel 传递切片时的数据竞争与深拷贝解决方案
jvm·数据库·python
qq_189807031 小时前
如何修改RAC数据库名_NID工具在集群环境下的改名步骤
jvm·数据库·python
aXin_ya2 小时前
Redis 高级篇(最佳实践)
数据库·redis·缓存
zhangchaoxies2 小时前
如何检测SQL注入风险_利用模糊测试技术发现漏洞
jvm·数据库·python
zhangchaoxies2 小时前
CSS如何实现响应式弹性网格布局_配合media query修改flex-wrap属性
jvm·数据库·python
霖霖总总2 小时前
[Redis小技巧32]Redis分布式锁的至暗时刻:从原理演进到时钟跳跃的终极博弈
数据库·redis·分布式
Polar__Star4 小时前
C#怎么操作Chart图表控件 C#如何用WinForms Chart控件绑定数据绘制统计图表【控件】
jvm·数据库·python
2401_897190554 小时前
CSS如何制作数字滚动效果_利用transform位移数字
jvm·数据库·python