mysql查询之后排列问题
问题描述
有两个2表,table1 和 table2问题如下:
select a.a,a.b from table1 a;select b.a,b.b from table2 b;有2个查询,比如table1 和 table2 都只有1条数据,我想把查询的结果放在一条 select a.a,a.b,b.a,b.b from table1 a,table2 b where a.id = b.aid这种是可以 然后b表有多条数据和a关联的时候的时候我想重命名字段名我想要的结果:select a.a,a.b,b.a,b.b,c.a,c.b from table1 a,table2 b,table2 c where a.id = b.aid and a.id=c.aid现在我不确定table2有几条数据是和table1绑定的,而且table2数据查询出来的字段如果有5条每条字段名称都需要重命名求个解决方法
可能是我描述的不清楚,连表查询可以的话,我也不需要提问了现在有3张表:A:id,caseid B:id,caseid,accidentid,name(张三) C:id,caseid,accident,name(李四) B和C 是同一张表,只是数据不同,但是都绑定这A我最后要查询出来的格式是:A.id,A.caseid,B.accident,B.name,C.accident,C.name 这是一条数据6列
问题解答
回答1:select * from table1 as a right join table2 as b on a.id = b.aid;
回答2:select * from table1 as a right join table2 as b on a.id = b.aid;
right join的用法这个语句的意思就是 以table2为主表连接table1
而且你拿出来的字段名字就是a.a等等啊,这个就不会重复了啊,因为你字段里制定了这个字段来自哪个表要是想重新命名可以使用 a.a as T1-a(任取名字)
select * from table2 as b left join table1 as a on a.id = b.aid;
也可以使用 left join 只是把table1和table2的位置换了一下!
回答3:问题1:返回不同数目的字段要放在一条sql里面?
问题2:是否只能table2最多有几条不同的字段?
相关文章:
1. nignx - docker内nginx 80端口被占用2. angular.js - angularjs的自定义过滤器如何给文字加颜色?3. android-studio - Android studio导入老版本的2048项目报错4. 为什么要通过常量的方式拐弯抹角的写呢,直接写DSN之类的不好吗5. php - mysql中,作为主键的字段,用int类型,是不是比用char类型的效率更高?6. 为什么return不了数据给ajax7. 急急急!!!求大神解答网站评论问题,有大神帮帮小弟吗8. PHP类属性声明?9. php mail无法发送邮件10. java - mybatis里的REGEXP
