mysql 怎么把查询结果作为表名继续查询

mysql 怎么把查询结果作为表名继续查询,第1张

mysql中把一个查询结果当作另一个表来查询可用as关键字先将查询结果作为一个临时表,然后使用select语句查询结果集即可。例如:

SELECT UserId FROM

(

   

SELECT UserId 

FROM OrderInfo  

GROUP BY UserId HAVING SUM(Amount)>30)

AS table1 

以上sql语句实现查询订单表中购买数量超过30的用户编号UserId,OrderInfo为订单表,查询结果作为临时表table1,然后从临时表中查询userid。

扩展资料

mysql中as用法介绍:用作、当成,作为;一般是重命名列名或者表名。(主要为了查询方便)

例如:

1、select  column_1  as  列1,column_2 as  列2   from  text as  表

解释:选择 column_1  作为 列1,column_2 作为 列2  从 text  当成 表。

2、select * from blog as B

解析:查找所有blog 表里面的数据,并把blog表格命名为 B。

1、创建三张测试表,

create table pw_memberinfo(uid int, name varchar(20))

create table pw_members(companyid int, uid int)

create table pw_memberdata(uid int, deposit int, ddeposit int, money int)

2、三张表,分别插入测试数据,

insert into pw_members values(1, 1)

insert into pw_members values(1, 2)

insert into pw_members values(1, 3)

insert into pw_memberinfo values(1, 'name_1')

insert into pw_memberinfo values(2, 'name_2')

insert into pw_memberinfo values(3, 'name_3')

insert into pw_memberdata values(1,30,50,150)

insert into pw_memberdata values(2,77,50,12)

insert into pw_memberdata values(3,44,50,82)

3、查看pw_memberdata表中的记录,select * from pw_memberdata t,

4、编写sql语句,

select * from (SELECT i.uid, sum(deposit+ddeposit+money) as allmoney

FROM pw_memberinfo i

LEFT JOIN pw_members m ON m.uid=i.uid

LEFT JOIN pw_memberdata d ON i.uid=d.uid

group by i.uid

) t where allmoney>200


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/zaji/5900975.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-07
下一篇 2023-03-07

发表评论

登录后才能评论

评论列表(0条)

保存