这里有新鲜出炉的 Mysql 教程,程序狗速度看过来!
MySQL 是一个开放源码的小型关联式数据库管理系统,开发者为瑞典 MySQL AB 公司。MySQL 被广泛地应用在 Internet 上的中小型网站中。由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,许多中小型网站为了降低网站总体拥有成本而选择了 MySQL 作为网站数据库。
这篇文章主要介绍了 Mysql 一些复杂的 sql 语句 (查询与删除重复的行), 需要的朋友可以参考下
1. 查找重复的行
- SELECT * FROM blog_user_relation a WHERE (a.account_instance_id,a.follow_account_instance_id)
- IN (SELECT account_instance_id,follow_account_instance_id FROM blog_user_relation GROUP BY account_instance_id, follow_account_instance_id HAVING
- COUNT(*) > 1)
2. 删除重复的行 (保留一条)
PS:因为 mysql 的 delete,如果被删的表的 where 条件里有 in,且 in 里面也有此表,那就删除不了。
- /*创建个临时表*/
- CREATE TABLE blog_user_relation_temp AS
- (
- SELECT * FROM blog_user_relation a WHERE
- (a.account_instance_id,a.follow_account_instance_id)
- IN ( SELECT account_instance_id,follow_account_instance_id FROM blog_user_relation GROUP BY account_instance_id, follow_account_instance_id HAVING COUNT(*) > 1)
- AND
- relation_id
- NOT IN (SELECT MIN(relation_id) FROM blog_user_relation GROUP BY account_instance_id, follow_account_instance_id HAVING COUNT(*)>1));
- /*删除数据*/
- DELETE FROM `blog_user_relation` WHERE relation_id IN (SELECT relation_id FROM blog_user_relation_temp);
- /*删除临时表*/
- DROP TABLE blog_user_relation_temp;
来源: http://www.phperz.com/article/17/0602/335556.html