mysql 去重,跨表更新,跨表删除
2016-08-16 14:15
218 查看
一、去重
1.查询出重复的记录
DELETE FROM 4a_org WHERE p_id IN (
SELECT org_id FROM 4a_org_tmp WHERE p_id IN
( SELECT org_id FROM 4a_org_tmp WHERE p_id IN
( SELECT org_id FROM 4a_org_tmp WHERE org_name='江西省') ) ) ; -- 学校DELETE FROM 4a_org WHERE p_id IN (
SELECT org_id FROM 4a_org_tmp WHERE p_id IN (
SELECT org_id FROM 4a_org_tmp WHERE org_name='江西省') ) ; -- 区/县DELETE FROM 4a_org WHERE p_id IN (
SELECT org_id FROM 4a_org_tmp WHERE org_name='江西省' ) ; -- 市DELETE FROM 4a_org WHERE org_name LIKE '%江西省%'; -- 省
1.查询出重复的记录
CREATE TABLE push_log_full_2013_10_30_tmp SELECT * FROM `push_log_full` WHERE time BETWEEN FROM_DAYS(TO_DAYS(NOW()) - 1) AND FROM_DAYS(TO_DAYS(NOW())) AND (imsi, andriodid, time) IN ( SELECT imsi, andriodid, time FROM `push_log_full` WHERE time BETWEEN FROM_DAYS(TO_DAYS(NOW()) - 1) AND FROM_DAYS(TO_DAYS(NOW())) GROUP BY imsi, andriodid, time HAVING COUNT(*) > 1)将重复的记录查出来放到一张临时表里面去。2删除push_log_full表中的重复数据。3将临时表的数据重新导入到push_log_full中。二、跨表更新法一:
UPDATE product p, productPrice pp SET pp.price = pp.price * 0.8 WHERE p.productId = pp.productId AND p.dateCreated < '2004-01-01'法二:
UPDATE product p INNER JOIN productPrice pp ON p.productId = pp.productId SET pp.price = pp.price * 0.8 WHERE p.dateCreated < '2004-01-01'法三多表更新:
UPDATE product p INNER JOIN productPrice pp ON p.productId = pp.productId SET pp.price = pp.price * 0.8, p.dateUpdate = CURDATE() WHERE p.dateCreated < '2004-01-01'三、跨表删除在Mysql4.0之后,mysql开始支持跨表delete。Mysql可以在一个sql语句中同时删除多表记录,也可以根据多个表之间的关系来删除某一个表中的记录。假定我们有两张表:Product表和ProductPrice表。前者存在Product的基本信息,后者存在Product的价格。第一种跨表删除的方式是不用join,在delete时指定用半角逗号分隔多个表来删除,如下sql语句:
DELETE p.*, pp.* FROM product p, productPrice pp WHERE p.productId = pp.productId AND p.created < '2004-01-01'第二种跨表删除的方式是使用inner join在join中指定两表之间的关联关系,如下sql语句:
DELETE p.*, pp.* FROM product p INNER JOIN productPrice pp ON p.productId = pp.productId WHERE p.created < '2004-01-01'跨表删除也可以使用left join,例如我们要删除所有在ProductPrice表中没有记录的Product表记录。如下sql语句:
DELETE p.* FROM product p LEFT JOIN productPrice pp ON p.productId = pp.productId WHERE pp.productId is null 单表级联删除
DELETE FROM 4a_org WHERE p_id IN (
SELECT org_id FROM 4a_org_tmp WHERE p_id IN
( SELECT org_id FROM 4a_org_tmp WHERE p_id IN
( SELECT org_id FROM 4a_org_tmp WHERE org_name='江西省') ) ) ; -- 学校DELETE FROM 4a_org WHERE p_id IN (
SELECT org_id FROM 4a_org_tmp WHERE p_id IN (
SELECT org_id FROM 4a_org_tmp WHERE org_name='江西省') ) ; -- 区/县DELETE FROM 4a_org WHERE p_id IN (
SELECT org_id FROM 4a_org_tmp WHERE org_name='江西省' ) ; -- 市DELETE FROM 4a_org WHERE org_name LIKE '%江西省%'; -- 省
相关文章推荐
- mysql 跨表查询、更新、删除示例
- mysql 跨表查询、更新、删除示例
- mysql 跨表查询, 更新,删除
- Mysql跨表更新,删除 多表update,delete
- Mysql 的on update/on delete定义父表上进行update/delete是更新或删除在子表的情况
- PHP+MYSQL新闻系统开发之后台更新与删除文件admin_news_class.php
- MySQL删除/更新数据时报1175错误
- Mysql跨表删除总结
- mysql 新增字段 添加字段 删除字段 修改字段 级联删除 级联更新 等
- python对MySQL进行数据的插入、更新和删除之后需要commit,数据库才会真的有数据操作。(待日后更新)
- mySQL 教程 第5章 插入 更新与删除数据
- MYSQL联合多表更新和删除
- MySQL删除更新数据时报1175错误
- MySQL学习笔记 第八讲:增加、删除、更新数据和备份还原
- mysql学习总结一当数据不存在的时候插入,存在的时候进行更新,删除重复数据
- servlet mysql的删除和更新
- MySQL 增加,更新,删除,查找数据
- MySQL跨表更新与数据合并的方法浅谈
- Mysql跨表更新 多表update sql语句总结
- 删除/var/lib/mysql-bin.000*文件 (二进制更新文件)导致mysql无法启动