MariaDB学习 专题
您的位置:database > MariaDB学习专题 > MariaDB 管理重复
MariaDB 管理重复
作者:--    发布时间:2019-11-20

如前面的课程所讨论的,mariadb在某些情况下允许重复记录和表。 由于不同的数据或对象类型,或作为操作对象的唯一寿命或存储的结果,这些重复中的一些事实上不是重复的。 这些副本通常也没有问题。

在某些情况下,重复确实会导致问题,并且它们常常由于隐式动作或mariadb命令的宽松策略而出现。 有多种方法可以控制此问题,查找重复项,删除重复项,并防止重复创建。

有四个关键方法来管理重复 - 

  • 使用join关联,并用临时表删除他们

  • 使用insert ... on duplicate key update在发现重复时更新。

  • 使用distinct修剪select语句的结果并删除重复的。

  • 使用insert ignore停止插入重复项。

使用连接临时表

只需像内部联接那样执行半连接,然后删除使用临时表找到的重复。

使用insert

当insert ... on duplicate key update发现重复的唯一或主键时,它执行更新。 发现多个唯一键时,它只更新第一个。 因此,不要在具有多个唯一索引的表上使用它。

查看以下示例,该示例显示在插入到填充字段时在包含索引值的表中发生的情况 -

insert into add_dupl values (1,'apple');
error 1062 (23000): duplicate entry '1' for key 'primary'

注意 - 如果没有找到任何键,insert ... on duplicate key update语句的执行方式与正常的insert语句相似。

使用distinct

distinct子句从结果中删除重复项。 distinct子句的一般语法如下 -

select distinct fields
from table
[where conditions];

注 - 带有distinct子句的语句的结果 - 

  • 当使用一个表达式时,它为它返回唯一的值。

  • 当使用多个表达式时,它返回唯一的组合。

  • 它不会忽略null值; 因此,结果还包含null作为唯一值。

使用单个表达式的distinct子句查看以下语句 -

select distinct product_id
from products
where product_name = 'dustblaster 5000';

使用多个表达式查看以下示例 -

select distinct product_name, product_id
from products
where product_id < 30

使用insert ignore

insert ignore语句指示mariadb在发现重复记录时取消插入。 查看下面给出的使用示例 -

mysql> insert ignore into customer_tbl (ln, fn)
   values( 'lex', 'luther');

另外,注意重复的逻辑。 某些表基于表数据的性质需要重复。 满足您在管理重复记录的策略中的需要。


网站声明:
本站部分内容来自网络,如您发现本站内容
侵害到您的利益,请联系本站管理员处理。
联系站长
373515719@qq.com
关于本站:
编程参考手册