MySQL在线运行

版本:

所属目录
点击了解高性能代码运行API
运行结果
教程手册
代码仓库
极速运行
终端运行
图形+终端

                        
以下是用户最新保存的代码
测试MySQL FLOAT类型 发布于:2025-01-13 15:17 在线测试sql 发布于:2025-01-07 18:51 费达二百v发的 发布于:2025-01-12 08:50 各机构资金来源总表 发布于:2025-01-06 09:56 我的MySQL测试使用的代码 发布于:2025-01-01 21:55 mysql环境 发布于:2024-12-31 00:04 ### # 这是我的第一个mysql文件****** ****** 发布于:2024-12-29 20:48 完整性确认 发布于:2024-12-29 20:39 并发控制与错误排除 发布于:2024-12-29 20:25 **mysql南方学院学生选课管理系统** 发布于:2024-12-27 01:42 学生选课数据库 发布于:2024-12-29 20:02 111111 1226 文字描述 发布于:2024-12-26 19:57 记录思路。。 发布于:2024-12-26 19:57 学习模板一 发布于:2024-12-25 23:26 区努玛的妈的 发布于:2024-12-25 16:06 徐娟你妈的 发布于:2024-12-25 14:18 博肖是真的 发布于:2024-12-25 15:46 MES拉动单执行情况 发布于:2024-12-26 19:58 MES拉动单执行情况备份 发布于:2024-12-24 18:48 MES拉动单执行时间备份 发布于:2024-12-25 10:42 MES拉动单执行时间 发布于:2024-12-24 18:45 我的代码是 发布于:2024-12-24 15:31 insert SC (sno,cno,grade) values(1,'c1',88); insert SC (sno,cno,grade) values(1,'c2',68); insert SC (sno,cno,grade) values(1,'c3',97); insert SC (sno,cno,grade) values(2,'c1',69); insert SC (sno,cno,grade) values(2,'c2',78); insert SC (sno,cno,grade) values(2,'c3',89); 发布于:2024-12-21 22:35 期末实验宿舍管理 发布于:2024-12-27 00:23 数据生成文件 发布于:2024-12-20 23:44 数据库运行 发布于:2024-12-20 15:30 数据库信息 发布于:2024-12-19 18:59 你一点也不好 发布于:2024-12-19 14:06 测试sql 发布于:2024-12-18 16:29 学生成绩数据库 发布于:2024-12-17 21:58 读入文件测试 发布于:2024-12-17 11:46 # mysql 地理数据 发布于:2024-12-15 13:26 创造一个用户并授权 发布于:2024-12-13 10:57 数据库作业学生选课 发布于:2024-12-12 16:21 汇总表(产品去重) 发布于:2024-12-09 10:35 mysql 测试 regexp 发布于:2024-12-06 16:43 42404921竹志伟 发布于:2024-12-07 20:52 42403923王华宇 发布于:2024-12-06 15:38 42404129-邓卫国 发布于:2024-12-06 15:26 42404922鲁佳宇 发布于:2024-12-06 15:26 赵翔42404510 发布于:2024-12-06 15:34 蒲峻杰42404145 发布于:2024-12-06 15:24 42403904-肖斌 发布于:2024-12-06 15:34 42404735-周悦 发布于:2024-12-06 15:21 申佳42404344 发布于:2024-12-06 15:34 42404822-黄俊翔 发布于:2024-12-06 15:10 42404823-吴孟柯 发布于:2024-12-06 15:21 42405118黄馨梦 发布于:2024-12-06 15:32 42404648蒋雪 发布于:2024-12-06 15:20 祁昊东 42404917 发布于:2024-12-06 15:23 [更多]
显示目录

处理重复数据



学习嵌入式的绝佳套件,esp8266开源小电视成品,比自己去买开发板+屏幕还要便宜,省去了焊接不当搞坏的风险。 蜂鸣版+触控升级仅36元,更强的硬件、价格全网最低。

点击购买 固件广场

处理重复数据

有些 MySQL 数据表中可能存在重复的记录,有些情况我们允许重复数据的存在,但有时候我们也需要删除这些重复的数据。

本章节我们将为大家介绍如何防止数据表出现重复数据及如何删除数据表中的重复数据。

防止表中出现重复数据

你可以在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如果存在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)
);

查询重复记录

select user_name,count(*) as count from user_table group by user_name having count>1;

select * from people 
where peopleId in (select peopleId from people group by peopleId having count(peopleId) > 1)

统计重复数据

以下我们将统计表中 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 表中重复的记录数。 一般情况下,查询重复的值,请执行以下操作:

  • 确定哪一列包含的值可能会重复。
  • 在列选择列表使用COUNT(*)列出的那些列。
  • 在GROUP BY子句中列出的列。
  • HAVING子句设置重复数大于1。

过滤重复数据

如果你需要读取不重复的数据可以在 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);

删除重复数据

如果你想删除数据表中的重复数据,你可以使用以下的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);
由JSRUN为你提供的MySQL在线运行、在线编译工具
        JSRUN提供的MySQL 在线运行,MySQL 在线运行工具,基于linux操作系统环境提供线上编译和线上运行,具有运行快速,运行结果与常用开发、生产环境保持一致的特点。
yout