• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

MYSQL 开发技艺_mysql

mysql 搞代码 7年前 (2018-06-09) 130次浏览 已收录 0个评论
文章目录[隐藏]

mysql 开发技巧

主要涉及: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,跪求各位点评,by 搞代码


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:MYSQL 开发技艺_mysql

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址