mysql select * from 表1 where name in(select * from 表2 where name like 'j%'); 请问表

兄弟们哪位知道,mysql select * from 表1 where name in(select * from 表2 where name like 'j%'); 请问表1和表2什么关系
最新回答
曾天真现成熟

2024-09-23 07:21:36

在此查询中,表1和表2中的name列相同的才被选出,也就是说,两张表的name有关联关系。

此sql语句可改写为:

select 表1.* from 表1,表2 where 表1.name=表2.name and 表2.name like 'j%';

其中,in的写法为子查询写法,改写后的写法为关联查询的写法。

残暴的安妮

2024-09-23 06:16:13

这个语句的意思是从表1中筛选表2中name字段以j开头的,这两个表的name字段需要有以j开头的相同的值才能筛选出结果来
追问
能举个例子吗
一清北华

2024-09-23 07:27:24

没有直接的关系,这个只是个关联查询,硬要说关系的话,在这里它们name里面可能会有一定相同的部分,
思念成灾*

2024-09-23 00:20:45

这只是mysql的一种语法,rlike就表示使用类似正则表达式的语法进行匹配。
也可以用regexp,它和rlike是同义词!
未来不动情

2024-09-23 07:00:54

只是两个表中有个字段的名字有点联系而已
追问
什么联系举个例子