duanchen9594 2014-12-08 19:50
浏览 11
已采纳

如何连接表以查找不存在的项目

my question may seem strange. But I have a question, how should I do a JOIN on a table for the following purpose:

I have a table called categories.

I have another pivot table called categories_products

Regularly I do a left join to get the categories of one product.

Now, after several month, there are some categories deleted from categories table. I had forgot to put a trigger at that time (that delete all related categories_products records of the deleted cat). I want to delete any record (which now is considered to be unused) from categories_products where its categories item is deleted (does not exist). What query should I write? Nothing comes to my mind. Thanks

  • 写回答

3条回答 默认 最新

  • doukong6031 2014-12-08 19:52
    关注
    delete from categories_products cp 
    where not exists (select 1 from categories c where c.id = cp.category_id);
    

    Or

    delete from categories_products cp 
    where cp.category_id not in (select distinct c.id from categories c);
    

    But EXISTS is usually faster.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥100 set_link_state
  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统
  • ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度