mysql 开发技巧之JOIN 更新和数据查重/去重

 更新时间:2016年09月29日 10:36:23   作者:_wave  
这篇文章主要介绍了mysql 开发技巧之JOIN 更新和数据查重/去重的相关资料,需要的朋友可以参考下

主要涉及:JOIN 、JOIN 更新、GROUP BY HAVING 数据查重/去重

1 INNER JOIN、LEFT JOIN、RIGHT JOIN、FULL JOIN(MySQL 不支持)、CROSS JOIN

这是在网上找到的非常好的一篇博文,图解 join 语句:

CODING HORROR-A Visual Explanation of SQL Joins

下图可以很清楚的明白,join 的数据选取范围

[][1]
[1]: http://7xs09x.com1.z0.glb.clouddn.com/160725-imooc-mysql-development-skills-notes-001.png

2 更新使用过滤条件中包括本身的表

更新 t1 t2 表中 col_a 重复的字段

UPDATE t1 
SET col_a = 'hi' 
WHERE t1.col_a IN (
 SELECT b.col_a
 FROM t1 a INNER JOIN t2 b on
 a.col_a = b.col_a
)
;
ERROR:1093 

可转换为:

UPDATE t1 aa JOIN(
 SELECT b.col_a
 FROM t1 a INNER JOIN t2 b on
 a.col_a = b.col_a
)bb on aa.col_a= bb.col_a
SET col_a = 'hi' 
;

3 查询重复数据、删除重复数据

利用 GROUP BY 和 HAVING 查询重复数据

SELECT col_a, COUNT(*)
FROM t1
GROUP BY col_a HAVING COUNT(*) > 1
;

删除重复数据,对于相同数据保留 ID 最大的

DELETE a
FROM t1 a JOIN (
 SELECT col_a,COUNT(*),MAX(id) AS id
 FROM t1
 GROUP BY col_a HAVING COUNT(*) > 1
)b ON a.col_a = b.col_a
WHERE a.id < b.id
;

感谢阅读此文,希望能帮助到大家,谢谢大家对本站的支持!

相关文章

  • MySQL中表子查询与关联子查询的基础学习教程

    MySQL中表子查询与关联子查询的基础学习教程

    这篇文章主要介绍了MySQL中表子查询与关联子查询的基础学习教程,同时文中也提到了关于关联子查询的查询效率问题,需要的朋友可以参考下
    2015-12-12
  • MySQL连接抛出Authentication Failed错误的分析与解决思路

    MySQL连接抛出Authentication Failed错误的分析与解决思路

    这篇文章主要给大家介绍了关于MySQL连接抛出Authentication Failed错误的分析与解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-10-10
  • 用SQL语句解决mysql导入大数据文件的问题

    用SQL语句解决mysql导入大数据文件的问题

    今天的这篇文章用来讨论如何解决导入mysql大数据文件的问题,其实说的简单了就是一条SQL语句,而如果你是一名SQL高手,那完全可以略过此文。
    2010-08-08
  • Mysql数据库的主从同步配置方式

    Mysql数据库的主从同步配置方式

    这篇文章主要介绍了Mysql数据库的主从同步配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-04-04
  • 在Linux系统的命令行中为MySQL创建用户的方法

    在Linux系统的命令行中为MySQL创建用户的方法

    这篇文章主要介绍了在Linux系统的命令行中为MySQL创建用户的方法,包括对所建用户的权限管理,需要的朋友可以参考下
    2015-06-06
  • 如何更改Linux(CentOS)系统下的MySQL数据库目录位置

    如何更改Linux(CentOS)系统下的MySQL数据库目录位置

    由于MySQL的数据库太大,默认安装的/var盘已经再也无法容纳新增加的数据, 没有办法,只能想办法转移数据的目录。 简单整理一下这几天把MySQL从/var/lib/mysql目录下面转移到/home/mysql_data/mysql下面具体操作
    2020-01-01
  • MySQL中计算两个日期的间隔天数方式

    MySQL中计算两个日期的间隔天数方式

    文章介绍了在MySQL 5.7中计算两个日期间隔天数的三种方法:DATEDIFF、TIMESTAMPDIFF和PERIOD_DIFF,并对比了它们的用途、参数和返回值类型
    2024-12-12
  • MySQL 表字段太多超长问题解决方案

    MySQL 表字段太多超长问题解决方案

    在设计MySQL数据库时,常遇到表字段超长问题,这是由字段数量过多或字段定义过长引起的,MySQL对字段数量和行大小有严格限制,超过限制将无法正常操作,本文就来介绍一下解决方法,感兴趣的可以了解一下
    2024-10-10
  • MySQL Event Scheduler(事件调度器)

    MySQL Event Scheduler(事件调度器)

    事件调度器是在 MySQL 5.1 中新增的另一个特色功能,可以作为定时任务调度器,取代部分原先只能用操作系统任务调度器才能完成的定时功能。
    2010-06-06
  • mysql中update按照多重条件进行更新处理的方案

    mysql中update按照多重条件进行更新处理的方案

    更新数据是使用数据库时最重要的任务之一,下面这篇文章主要给大家介绍了关于mysql中update按照多重条件进行更新处理的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-09-09

最新评论