sql表关联查询,表查询出数据插入到另一张,使用正则查询,查询结果集转换为JSON数据


复制代码
select a.userId,a.userName,
       b.sex_describe,a.userAge
       from test_1 a join test_2 b on a.userSex = b.sex_id;
with t as(
  select t2.sex_id,t2.sex_describe from test_2 t2
)select t1.userId,t1.userAge,t.sex_describe,t1.userName
from test_1 t1,t where t1.userSex = t.sex_id;

1.查询出数据更新到另一张表 需求:从A表查询出字段数据,更新到B表对应的字段 示例:当table_a表中的b_id=table_b表的id时,将table_b表中的sn,filed1更新到table_a

表中sn,filed1字段

复制代码
-- 更新数据
UPDATE `table_a` r
INNER JOIN (SELECT id,sn,filed1 FROM `table_b`) t ON r.b_id= t.id
SET r.sn = t.sn,r.filed1 = t.filed1 

2.一张表查询出数据插入到另一张 insert into table_a(字段1,字段2,字段3,...) select a,b,c,... from table_b where 条件 示例:

复制代码
insert into table_a(`name`,`age`,`gender`) select b_name,b_age,b_gender from table_b where id = 5;

说明: 1、table_a表插入的字段个数必须同select后面跟的字段个数一致 2、where条件可以写多个

3、select后面跟的字段可以写固定值(部分写死,全部写死相当于直接insert,这样就没必要查询) 示例:insert into

table_a(name,age,gender) select '张三', 18, b_gender from table_b

where id = 5;

1.如果2张表的字段一致,并且希望插入全部数据,可以用这种方法:

复制代码
 INSERT INTO 目标表 SELECT * FROM 来源表;
 例如:insert into insertTest1 select * from insertTest2;

2.如果只希望导入指定字段,可以用这种方法:

复制代码
 INSERT  INTO 目标表 (字段1, 字段2, ...) SELECT 字段1, 字段2,... FROM 来源表;(字段必须保持一致)
 例如:insert into insertTest2(id,name) select id,name from insertTest1;

注意:如果目标表与来源表主键值相同则会出现添加错误,主键值不同才能插入

3.如果您需要只导入目标表中不存在的记录,可以使用这种方法:

复制代码
INSERT INTO 目标表 (字段1, 字段2, ...) SELECT 字段1, 字段2, ... FROM来源表 
WHERE not exists (select * from 目标表 where 目标表.比较字段 = 来源表.比较字段); 

 1>.插入多条记录:
   insert into  insertTest2(id,name) select  id,name from insertTest
 where not exists (select * from insertTest2 where insertTest2.id=insertTest.id);
 2>.插入一条记录:
   insert into insertTest (id, name) SELECT 100,'liudehua'  FROM dual 
         WHERE not exists (select * from insertTest where insertTest.id = 100);

3、如果需要导入的目标表字段比来源表的字段多,将来源表的数据导入再加上几个字段组成目标表的数据

复制代码
 select 目标字段1,目标字段2,字段1, 字段2,... FROM来源表  

insert into insertTest2(目标字段1,目标字段2,id,name) select 目标字段1,
     目标字段2, id,name from insertTest  where insertTest2.id=insertTest.id;
 目标字段1,目标字段2:可以先设占位符,在设置值。也可以直接在语句中赋值
insert into insertTest2(目标字段1,目标字段2,id,name) select  a1,
     a2, id,name from insertTest  where insertTest2.id=insertTest.id;

5、对上述4的解析
select a1, a2, id,name from insertTest

这里在表 insertTest里本身没有a1,a2两个字段名,当使用这个查询语句时,会查出

insertTest表的所有字段值,并在表数据的前面加上了列名为a1,a2的字段,并且列名为a1的值全为a1,列名为a2的值全为a2,并且a1,a2不能为变量,如果是变量,sql语句会把它当做表字段,而表中不存在这个字段,会报错
总结:即可以向一个表中查询不存在的列名,这里不存在的列名必须是实际值或占位符,不能是变量

相关推荐
DarkAthena31 分钟前
【GaussDB】执行索引跳扫时如果遇到该索引正在执行autovacuum,可能会导致数据查询不到
数据库·gaussdb
短剑重铸之日1 小时前
《7天学会Redis》Day 5 - Redis Cluster集群架构
数据库·redis·后端·缓存·架构·cluster
007php0071 小时前
mySQL里有2000w数据,Redis中只存20w的数据,如何保证Redis中的数据都是热点数据
数据库·redis·git·mysql·面试·职场和发展·php
lkbhua莱克瓦241 小时前
进阶-存储过程3-存储函数
java·数据库·sql·mysql·数据库优化·视图
老邓计算机毕设2 小时前
SSM心理健康系统84459(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架·心理健康系统·在线咨询
碎像2 小时前
10分钟搞定 MySQL 通过Binlog 数据备份和恢复
数据库·mysql
+VX:Fegn08952 小时前
计算机毕业设计|基于springboot + vue小型房屋租赁系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
win x2 小时前
Redis 分布式锁
数据库·redis·分布式
2501_944521002 小时前
rn_for_openharmony商城项目app实战-商品评价实现
javascript·数据库·react native·react.js·ecmascript·harmonyos