表复制某些字段的操作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);
相关推荐
友友马几秒前
『QT』窗口 (一)
开发语言·数据库·qt
q***78372 分钟前
SQL实现md5加密方法
数据库·sql
q***614113 分钟前
Spring中Aware的用法以及实现
java·数据库·spring
红树林0722 分钟前
渗透测试之sql注入--报错注入
数据库·sql·安全·web安全
菜鸟小九1 小时前
mysql(锁)
数据库·mysql·oracle
c***42101 小时前
【Sql Server】随机查询一条表记录,并重重温回顾下自定义函数的封装和使用
数据库·性能优化
Appreciate(欣赏)1 小时前
JAVA使用poi类读取xlxs文件内容拼接成添加数据SQL
java·开发语言·sql
q***44812 小时前
PostgreSQL的备份方式
数据库·postgresql
v***59832 小时前
【SQL Server】超详细SQLServer日期转换、字符串、数学、聚合等常用函数大全(最新版)
数据库·sqlserver
q***23572 小时前
python的sql解析库-sqlparse
数据库·python·sql