MySQL中處理各種重復的一些方法
有時表或結(jié)果集包含重復的記錄。有時它是允許的,但有時它需要停止重復的記錄。有時它需要識別重復的記錄從表中刪除。本章將介紹如何防止發(fā)生在一個表中重復的記錄如何刪除已經(jīng)存在的重復記錄。
防止重復表中的發(fā)生:
可以使用PRIMARY KEY或UNIQUE索引的表上相應的字段來防止重復的記錄。讓我們舉一個例子,下面的表中不包含這樣的索引或主鍵,所以它會允許記錄first_name和last_name重復
CREATE TABLE person_tbl ( first_name CHAR(20), last_name CHAR(20), sex CHAR(10) );
可以使用PRIMARY KEY或UNIQUE索引的表上相應的字段防止重復的記錄。讓我們舉一個例子,下面的表中不包含這樣的索引或主鍵,所以它會允許重復first_name和last_name記錄
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) );
表中的唯一索引的存在通常會導致錯誤的發(fā)生,如果表中插入一條記錄,重復定義索引的列或列中的現(xiàn)有記錄。
使用INSERT IGNORE而不是INSERT。如果記錄不重復現(xiàn)有的記錄,MySQL將插入它像往常一樣。如果記錄是重復IGNORE關(guān)鍵字告訴MySQL靜靜地拋棄它,而不會產(chǎn)生錯誤。
下面的示例中沒有錯誤,同時也不會插入重復的記錄。
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。如果記錄是新的它INSERT插入。如果它是一個重復的,新的記錄將取代舊的:
mysql> REPLACE INTO person_tbl (last_name, first_name) -> VALUES( 'Ajay', 'Kumar'); Query OK, 1 row affected (0.00 sec) mysql> REPLACE INTO person_tbl (last_name, first_name) -> VALUES( 'Ajay', 'Kumar'); Query OK, 2 rows affected (0.00 sec)
使用REPLACE而不是INSERT。如果記錄是新的它INSERT插入。如果它是一個重復的,新的記錄將取代舊的:
強制唯一性的另一種方法是添加一個UNIQUE索引,而不是一個PRIMARY KEY表。
CREATE TABLE person_tbl ( first_name CHAR(20) NOT NULL, last_name CHAR(20) NOT NULL, sex CHAR(10) UNIQUE (last_name, first_name) );
計算和確定重復:
以下是查詢數(shù)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表中重復的記錄。在一般情況下,識別重復的值,請執(zhí)行以下操作:
- 確定哪一列包含的值可能會重復。
- 在列選擇列表中隨著COUNT(*)列出的那些列。
- 以及在GROUP BY子句中列出的列。
- 新增的HAVING子句消除了獨特的值要求的組數(shù)大于1。
消除重復查詢結(jié)果:
可以使用DISTINCT與SELECT語句一起找出表中唯一的紀錄。
mysql> SELECT DISTINCT last_name, first_name -> FROM person_tbl -> ORDER BY last_name;
DISTINCT是添加一個GROUP BY子句中命名的列,選擇的另一種方法。這具有除去重復和只選擇的獨特的組合中的指定的列的值的效果:
mysql> SELECT last_name, first_name -> FROM person_tbl -> GROUP BY (last_name, first_name);
刪除重復使用表更換:
如果在一個表中有重復的記錄,想從該表中刪除所有的重復記錄,看看下面程序的例子。
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;
從一個表中刪除重復記錄的一個簡單的方法是添加KEY,表索引或PRIMAY。如果該表已經(jīng)是可用的,那么使用此方法刪除重復的記錄。
mysql> ALTER IGNORE TABLE person_tbl -> ADD PRIMARY KEY (last_name, first_name);
相關(guān)文章
MySQL5.7.24版本的數(shù)據(jù)庫安裝過程圖文詳解
這篇文章主要介紹了MySQL5.7.24版本的數(shù)據(jù)庫安裝過程,需要的朋友可以參考下2018-11-11
解析MYSQL 數(shù)據(jù)庫導入SQL 文件出現(xiàn)亂碼的問題
本篇文章是對MYSQL數(shù)據(jù)庫導入SQL文件出現(xiàn)亂碼的問題進行了詳細的分析介紹,需要的朋友參考下2013-06-06
MySQL數(shù)據(jù)庫varchar的限制規(guī)則說明
本文我們主要介紹了MySQL數(shù)據(jù)庫中varchar的限制規(guī)則,并以一個實際的例子對限制規(guī)則進行了說明,希望能夠?qū)δ兴鶐椭?/div> 2011-08-08
CentOS 7.0如何啟動多個MySQL實例教程(mysql-5.7.21)
這篇文章主要給大家介紹了關(guān)于CentOS 7.0如何啟動多個MySQL實例(mysql-5.7.21)的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起看看吧。2018-03-03最新評論

