這個(gè)的話 沒有你說的clear all user(1)這種寫法吧!如果要實(shí)現(xiàn)清空其它字段的值,留下這條記錄只剩下ID的值,那就只能用update了吧,把后面的字段清空,這樣還是行的。呵呵
成都創(chuàng)新互聯(lián)專注于城廂企業(yè)網(wǎng)站建設(shè),成都響應(yīng)式網(wǎng)站建設(shè)公司,商城網(wǎng)站定制開發(fā)。城廂網(wǎng)站建設(shè)公司,為城廂等地區(qū)提供建站服務(wù)。全流程按需定制制作,專業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,成都創(chuàng)新互聯(lián)專業(yè)和態(tài)度為您提供的服務(wù)
MySQL中的UNION
ALL
而UNION
ALL只是簡單的將兩個(gè)結(jié)果合并后就返回。這樣,如果返回的兩個(gè)結(jié)果集中有重復(fù)的數(shù)據(jù),那么返回的結(jié)果集就會包含重復(fù)的數(shù)據(jù)了。
從效率上說,UNION
ALL
要比UNION快很多,所以,如果可以確認(rèn)合并的兩個(gè)結(jié)果集中不包含重復(fù)的數(shù)據(jù)的話,那么就使用UNION
ALL,如下:
select
*
from
gc_dfys
union
all
select
*
from
ls_jg_dfys
使用Union,則所有返回的行都是唯一的,如同您已經(jīng)對整個(gè)結(jié)果集合使用了DISTINCT
使用Union
all,則不會排重,返回所有的行
如果您想使用ORDER
BY或LIMIT子句來對全部UNION結(jié)果進(jìn)行分類或限制,則應(yīng)對單個(gè)地SELECT語句加圓括號,并把ORDER
BY或LIMIT放到最后一個(gè)的后面:
(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;
麻煩一點(diǎn)也可以這么干:
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的括號后面必須有個(gè)別名,否則會報(bào)錯(cuò)
當(dāng)然了,如果當(dāng)union的幾個(gè)表的數(shù)據(jù)量很大時(shí),建議還是采用先導(dǎo)出文本,然后用腳本來執(zhí)行
因?yàn)榧兇庥胹ql,效率會比較低,而且它會寫臨時(shí)文件,如果你的磁盤空間不夠大,就有可能會出錯(cuò)
Error
writing
file
'/tmp/MYLsivgK'
(Errcode:
28)
在數(shù)據(jù)庫中,UNION和UNION
ALL關(guān)鍵字都是將兩個(gè)結(jié)果集合并為一個(gè),但這兩者從使用和效率上來說都有所不同。
MySQL中的UNION
UNION在進(jìn)行表鏈接后會篩選掉重復(fù)的記錄,所以在表鏈接后會對所產(chǎn)生的結(jié)果集進(jìn)行排序運(yùn)算,刪除重復(fù)的記錄再返回結(jié)果。實(shí)際大部分應(yīng)用中是不會產(chǎn)生重復(fù)的記錄,最常見的是過程表與歷史表UNION。如:
select
*
from
gc_dfys
union
select
*
from
ls_jg_dfys
這個(gè)SQL在運(yùn)行時(shí)先取出兩個(gè)表的結(jié)果,再用排序空間進(jìn)行排序刪除重復(fù)的記錄,最后返回結(jié)果集,如果表數(shù)據(jù)量大的話可能會導(dǎo)致用磁盤進(jìn)行排序。
MySQL中的UNION
ALL
而UNION
ALL只是簡單的將兩個(gè)結(jié)果合并后就返回。這樣,如果返回的兩個(gè)結(jié)果集中有重復(fù)的數(shù)據(jù),那么返回的結(jié)果集就會包含重復(fù)的數(shù)據(jù)了。
從效率上說,UNION
ALL
要比UNION快很多,所以,如果可以確認(rèn)合并的兩個(gè)結(jié)果集中不包含重復(fù)的數(shù)據(jù)的話,那么就使用UNION
ALL,如下:
select
*
from
gc_dfys
union
all
select
*
from
ls_jg_dfys