很周全的MySQL處置反復數據代碼。本站提示廣大學習愛好者:(很周全的MySQL處置反復數據代碼)文章只能為提供參考,不一定能成為您想要的結果。以下是很周全的MySQL處置反復數據代碼正文
有些 MySQL 數據表中能夠存在反復的記載,有些情形我們許可反復數據的存在,但有時刻我們也須要刪除這些反復的數據。
本章節我們將為年夜家引見若何避免數據表湧現反復數據及若何刪除數據表中的反復數據。
1、避免表中湧現反復數據
你可以在MySQL數據表中設置指定的字段為 PRIMARY KEY(主鍵) 或許 UNIQUE(獨一) 索引來包管數據的獨一性。
讓我們測驗考試一個實例:下表中無索引及主鍵,所以該表許可湧現多條反復記載。
CREATE TABLE person_tbl ( first_name CHAR(20), last_name CHAR(20), sex CHAR(10) );
假如你想設置表中字段first_name,last_name數據不克不及反復,你可以設置雙主鍵形式來設置數據的獨一性, 假如你設置了雙主鍵,那末誰人鍵的默許值不克不及為NULL,可設置為NOT NULL。以下所示:
CREATE TABLE person_tbl ( first_name CHAR(20) NOT NULL, last_name CHAR(20) NOT NULL, sex CHAR(10), PRIMARY KEY (last_name, first_name) );
假如我們設置了獨一索引,那末在拔出反復數據時,SQL語句將沒法履行勝利,並拋失足。
INSERT IGNORE INTO與INSERT INTO的差別就是INSERT IGNORE會疏忽數據庫中曾經存在的數據,假如數據庫沒稀有據,就拔出新的數據,假如稀有據的話就跳過這條數據。如許便可以保存數據庫中曾經存在數據,到達在間隙中拔出數據的目標。
以下實例應用了INSERT IGNORE INTO,履行後不會失足,也不會向數據表中拔出反復數據:
mysql> INSERT IGNORE INTO person_tbl (last_name, first_name) -> VALUES( 'Jay', 'Thomas'); Query OK, 1 row affected (0.00 sec) mysql> INSERT IGNORE INTO person_tbl (last_name, first_name) -> VALUES( 'Jay', 'Thomas'); Query OK, 0 rows affected (0.00 sec)
INSERT IGNORE INTO當拔出數據時,在設置了記載的獨一性後,假如拔出反復數據,將不前往毛病,只以正告情勢前往。 而REPLACE INTO into假如存在primary 或 unique雷同的記載,則先刪除失落。再拔出新記載。
另外一種設置數據的獨一性辦法是添加一個UNIQUE索引,以下所示:
CREATE TABLE person_tbl ( first_name CHAR(20) NOT NULL, last_name CHAR(20) NOT NULL, sex CHAR(10) UNIQUE (last_name, first_name) );
2、統計反復數據
以下我們將統計表中 first_name 和 last_name的反復記載數:
mysql> SELECT COUNT(*) as repetitions, last_name, first_name -> FROM person_tbl -> GROUP BY last_name, first_name -> HAVING repetitions > 1;
以上查詢語句將前往 person_tbl 表中反復的記載數。 普通情形下,查詢反復的值,請履行以下操作:
1、肯定哪一列包括的值能夠會反復。
2、在列選擇列表應用COUNT(*)列出的那些列。
3、在GROUP BY子句中列出的列。
4、HAVING子句設置反復數年夜於1。
3、過濾反復數據
假如你須要讀取不反復的數據可以在 SELECT 語句中應用 DISTINCT 症結字來過濾反復數據。
mysql> SELECT DISTINCT last_name, first_name -> FROM person_tbl -> ORDER BY last_name;
你也能夠應用 GROUP BY 來讀取數據表中不反復的數據:
mysql> SELECT last_name, first_name -> FROM person_tbl -> GROUP BY (last_name, first_name);
4、刪除反復數據
假如你想刪除數據表中的反復數據,你可使用以下的SQL語句:
mysql> CREATE TABLE tmp SELECT last_name, first_name, sex -> FROM person_tbl; -> GROUP BY (last_name, first_name); mysql> DROP TABLE person_tbl; mysql> ALTER TABLE tmp RENAME TO person_tbl;
固然你也能夠在數據表中添加 INDEX(索引) 和 PRIMAY KEY(主鍵)這類簡略的辦法來刪除表中的反復記載。辦法以下:
mysql> ALTER IGNORE TABLE person_tbl -> ADD PRIMARY KEY (last_name, first_name);
以上就是關於MySQL處置反復數據的全體內容,願望對年夜家的進修有所贊助。