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条)

报告相同问题?

悬赏问题

  • ¥15 怎么改成循环输入删除(语言-c语言)
  • ¥15 安卓C读取/dev/fastpipe屏幕像素数据
  • ¥15 pyqt5tools安装失败
  • ¥15 mmdetection
  • ¥15 nginx代理报502的错误
  • ¥100 当AWR1843发送完设置的固定帧后,如何使其再发送第一次的帧
  • ¥15 图示五个参数的模型校正是用什么方法做出来的。如何建立其他模型
  • ¥100 描述一下元器件的基本功能,pcba板的基本原理
  • ¥15 STM32无法向设备写入固件
  • ¥15 使用ESP8266连接阿里云出现问题