思路:數(shù)據(jù)庫如果存在就更新,不存在就插入
鹽田網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)建站!從網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、自適應(yīng)網(wǎng)站建設(shè)等網(wǎng)站項目制作,到程序開發(fā),運(yùn)營維護(hù)。創(chuàng)新互聯(lián)建站成立于2013年到現(xiàn)在10年的時間,我們擁有了豐富的建站經(jīng)驗和運(yùn)維經(jīng)驗,來保證我們的工作的順利進(jìn)行。專注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)建站。
首先:1.對你要設(shè)置的表,點(diǎn)擊右鍵--管理索引--新建--選擇要唯一的主鍵--在“索引選項”中選擇“唯一性”--應(yīng)用
思路:數(shù)據(jù)庫如果存在就更新,不存在就插入
1.對你要設(shè)置的表,點(diǎn)擊右鍵--管理索引--新建--選擇要唯一的主鍵--在“索引選項”中選擇“唯一性”--應(yīng)用
2、語句:INSERT INTO 表名(字段,字段,字段,字段) VALUES ('127.0.0.5','1',NOW(),NOW())
ON DUPLICATE KEY UPDATE 字段 = online_num+1,last_time = NOW();
自己延伸一下就明白了
場景:表中包含有g(shù)roup_id,worker_id,status字段,查詢這三個字段是否存在重復(fù)的數(shù)據(jù)。
查找某個人在某個班組內(nèi)存在多個status為0的數(shù)據(jù)
查找某個人在某個班組內(nèi)存在多個status為0的數(shù)據(jù),將最小的id選出來
查找某個人在某個班組內(nèi)存在多個status為0的數(shù)據(jù),將最小的id選出來,并設(shè)置status為1
將查詢查詢結(jié)果作為where in的條件,需要select的結(jié)果再通過一個中間表select多一次,否則會報You can't specify target table for update in FROM clause。
MySQL 過濾重復(fù)數(shù)據(jù)
有些 MySQL 數(shù)據(jù)表中可能存在重復(fù)的記錄,有些情況我們允許重復(fù)數(shù)據(jù)的存在,但有時候我們也需要刪除這些重復(fù)的數(shù)據(jù)。
如果你需要讀取不重復(fù)的數(shù)據(jù)可以在 SELECT 語句中使用 DISTINCT 關(guān)鍵字來過濾重復(fù)數(shù)據(jù)。
from 樹懶學(xué)堂- 一站式數(shù)據(jù)知識學(xué)習(xí)平臺
你也可以使用 GROUP BY 來讀取數(shù)據(jù)表中不重復(fù)的數(shù)據(jù):
MySQL 刪除重復(fù)數(shù)據(jù)
有些 MySQL 數(shù)據(jù)表中可能存在重復(fù)的記錄,有些情況我們允許重復(fù)數(shù)據(jù)的存在,但有時候我們也需要刪除這些重復(fù)的數(shù)據(jù)。
本章節(jié)我們將為大家介紹如何防止數(shù)據(jù)表出現(xiàn)重復(fù)數(shù)據(jù)及如何刪除數(shù)據(jù)表中的重復(fù)數(shù)據(jù)。
刪除重復(fù)數(shù)據(jù)
如果你想刪除數(shù)據(jù)表中的重復(fù)數(shù)據(jù),你可以使用以下的SQL語句:
from 樹懶學(xué)堂 - 一站式數(shù)據(jù)知識平臺
當(dāng)然你也可以在數(shù)據(jù)表中添加 INDEX(索引) 和 PRIMAY KEY(主鍵)這種簡單的方法來刪除表中的重復(fù)記錄。方法如下:
可以新建立一張表,
把重復(fù)數(shù)據(jù)的字段設(shè)置為索引,
不允許重復(fù),再把之前的表數(shù)據(jù)導(dǎo)入到新建立的表中,
這樣就可以過濾掉重復(fù)內(nèi)容了。
select
distinct可以去掉重復(fù)記錄。
disctinct將重復(fù)的記錄忽略,但它忽略的是完全一致的重復(fù)記錄,而不是其中某個字段重復(fù)的記錄,或者說,distinct查詢一個字段時好使,多個字段就不好使。
所以用聚合函數(shù)和group
by實現(xiàn)
注意:group
by只能跟聚合函數(shù)搭配使用
例表
ID
username
password
TRDESC
1
A
abcdef
QR
2
A
abcdef
W34
3
A
bbbbbb
AD
4
B
aaaaaa
asdf
查詢username和password組合起來的條件不能重復(fù)的查詢結(jié)果(這個都能重復(fù),不能不說這是個爛攤子)
select
*
from
mytable
where
ID
in(select
max(ID)
from
mytable
group
by
username,password)
當(dāng)username和password重復(fù)時,取ID最小的記錄:
select
*
from
mytable
where
ID
in(select
min(ID)
from
mytable
a
group
by
username,password)