mysql合并结果集

mysql合并结果集,第1张

MySQL中的UNION

ALL

而UNION

ALL只是简单的将两个结果合并后就返回。这样,如果返回的两个结果集中有重复的数据,那么返回的结果集就会包含重复的数据了。

从效率上说,UNION

ALL

要比UNION快很多,所以,如果可以确认合并的两个结果集中不包含重复的数据的话,那么就使用UNION

ALL,如下:

select

*

from

gc_dfys

union

all

select

*

from

ls_jg_dfys

使用Union,则所有返回的行都是唯一的,如同您已经对整个结果集合使用了DISTINCT

使用Union

all,则不会排重,返回所有的行

如果您想使用ORDER

BY或LIMIT子句来对全部UNION结果进行分类或限制,则应对单个地SELECT语句加圆括号,并把ORDER

BY或LIMIT放到最后一个的后面:

(SELECT

a

FROM

tbl_name

WHERE

a=10

AND

B=1)

UNION

(SELECT

a

FROM

tbl_name

WHERE

a=11

AND

B=2)

ORDER

BY

a

LIMIT

10

麻烦一点也可以这么干:

select

userid

from

(

select

userid

from

testa

union

all

select

userid

from

testb)

as

t

order

by

userid

limit

0,1

如果你还想group

by,而且还有条件,那么:

select

userid

from

(select

userid

from

testa

union

all

select

userid

from

testb)

t

group

by

userid

having

count(userid)

=

2

注意:在union的括号后面必须有个别名,否则会报错

当然了,如果当union的几个表的数据量很大时,建议还是采用先导出文本,然后用脚本来执行

因为纯粹用sql,效率会比较低,而且它会写临时文件,如果你的磁盘空间不够大,就有可能会出错

Error

writing

file

'/tmp/MYLsivgK'

(Errcode:

28)

您好.

以前有高人写过类似的:

select id,group_concat(re_id order by re_id separator ",") as re_id

from tablename

group by id

方法2:

select group_concat(list_name) from aa_list

如果还有问题,可以继续追问,感谢。

首先解决,查询数据

1

select userlist.userid,userlist.username,userinformation.address from userlist left join userinformation on userlist.userid=userinformation.userid

然后,再把查询数据,插入到新表即可

只要在上面的语句,加上插入这句sql就可以了,最终语句如下

1

insert into `user` select userlist.userid,userlist.username,userinformation.address from userlist left join userinformation on userlist.userid=userinformation.userid


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

原文地址: http://outofmemory.cn/zaji/8508040.html

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

发表评论

登录后才能评论

评论列表(0条)

保存