• 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
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    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 
    
    • 1
    • 2
    • 3
    • 4

    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

    说明: 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;
    
    • 1
    • 2

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

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

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

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

    INSERT INTO 目标表 (字段1, 字段2, ...) SELECT 字段1, 字段2, ... FROM来源表 
    WHERE not exists (select * from 目标表 where 目标表.比较字段 = 来源表.比较字段); 
    
    • 1
    • 2
     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);
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

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

     select 目标字段1,目标字段2,字段1, 字段2,... FROM来源表  
    
    • 1
    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;
    
    • 1
    • 2
    • 3
    • 4
    • 5

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

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

    使用正则表达式查询

    正则表达式是用某种模式去匹配一类字符串的一个方式。例如,使用正则表达式可以查询出包含A、B、C其中任一字母的字符串。正则表达式的查询能力比通配字符的查询能力更强大,而且更加的灵活。正则表达式可以应用于非常复杂查询。
    MySQL中,使用REGEXP关键字来匹配查询正则表达式。其基本形式如下: 属性名 REGEXP ‘匹配方式’

    (1)使用字符“^”可以匹配以特定字符或字符串开头的记录。
    查询所有以阿头的
    select * from STUDENT where STU_NAME REGEXP  '^阿';
    以数字开头
    select * from STUDENT where STU_NAME REGEXP '^[0-9]';
    (2)使用字符“$”可以匹配以特定字符或字符串结尾的记录
    以数字结尾
    select * from STUDENT where STU_NAME REGEXP '[0-9]$';
    (3)用正则表达式来查询时,可以用“.”来替代字符串中的任意一个字符。
    select * from STUDENT where STU_NAME REGEXP '^w....[0-9]$';
    以w开头,以数字结束,中间有4个
    (4)使用方括号([])可以将需要查询字符组成一个字符集。只要记录中包含方括号中的任意字符,该记录将会被查询出来。
    例如,通过“[abc]”可以查询包含a、b、c这三个字母中任何一个的记录。
    使用方括号可以指定集合的区间。
    “[a-z]”表示从a-z的所有字母;
    “[0-9]”表示从0-9的所有数字;
    “[a-z0-9]”表示包含所有的小写字母和数字。
    “[a-zA-Z]”表示匹配所有字母。
    select * from STUDENT where STU_NAME REGEXP '[0-9a-z]';
    查询所有包含有数字和小写字母的
    使用“[^字符集合]”可以匹配指定字符以外的字符
    (5){}表示出现的次数
    正则表达式中,“字符串{M}”表示字符串连续出现M次;“字符串{M,N}”表示字符串联连续出现至少M次,最多N次。例如,“ab{2}”表示字符串“ab”连续出现两次。“ab{2,4}”表示字符串“ab”连续出现至少两次,最多四次。
    o出现2次
    select * from STUDENT where STU_NAME REGEXP 'o{2}';
    (6)+表示到少出现一次
    fa至少出现一次
    select * from STUDENT where STU_NAME REGEXP '(fa)+';
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28

    注意:
    正则表达式可以匹配字符串。当表中的记录包含这个字符串时,就可以将该记录查询出来。如果指定多个字符串时,需要用符号“|”隔开。只要匹配这些字符串中的任意一个即可。每个字符串与”|”之间不能有空格。因为,查询过程中,数据库系统会将空格也当作一个字符。这样就查询不出想要的结果。
    正则表达式中,“”和“+”都可以匹配多个该符号之前的字符。但是,“+”至少表示一个字符,而“”可以表示零个字符。

  • 相关阅读:
    分布式调度Zookeeper常用Shell命令【云原生】
    配置资源管理
    I/O控制方式(程序直接控制方式,中断驱动方式,DMA方式,通道控制方式)
    Qt右键菜单
    Python + Django4 搭建个人博客(五): 创建并连接数据库
    Windows OpenGL ES 波浪特效
    ChatGPT Prompting开发实战(七)
    多功能手机无线充触摸IC-DLT8SA15B
    2016-2023全国MPA国家A类线趋势图:浙大MPA要高多少?
    C语言:数组指针
  • 原文地址:https://blog.csdn.net/qq_37823919/article/details/133660058