dphe5602 2014-02-26 15:10
浏览 652
已采纳

在子查询后删除并返回结果

Right now I have the following SQL statement that I'm calling in PHP:

SELECT * FROM activity WHERE id=(
    SELECT activity_id FROM session_notifications
    WHERE session_id='{$session}');

This pulls table data from activities that are referenced in the session_notification table. All good. Now, is there an easy way to do this, but also in the same statement delete all of the rows returned by checking session_notifications?

** Edit: To be more clear, I do not want to delete the activity since I'll need that information. I want to delete the rows in session_notifications that were hit. Why? Because I don't want anything to have been added in afterwards. However, I might be okay since SQL tables are thread safe, yes?

  • 写回答

2条回答 默认 最新

  • douche3244 2014-02-26 15:19
    关注

    If you want to make sure you will delete the records shown in the select, you must use a transaction.

    START TRANSACTION;
    SELECT * FROM activity WHERE id IN (
        SELECT activity_id FROM session_notifications
        WHERE session_id='{$session}');
    DELETE FROM activity WHERE id IN (
        SELECT activity_id FROM session_notifications
        WHERE session_id='{$session}');
    COMMIT;
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 拟通过pc下指令到安卓系统,如果追求响应速度,尽可能无延迟,是不是用安卓模拟器会优于实体的安卓手机?如果是,可以快多少毫秒?
  • ¥20 神经网络Sequential name=sequential, built=False
  • ¥16 Qphython 用xlrd读取excel报错
  • ¥15 单片机学习顺序问题!!
  • ¥15 ikuai客户端多拨vpn,重启总是有个别重拨不上
  • ¥20 关于#anlogic#sdram#的问题,如何解决?(关键词-performance)
  • ¥15 相敏解调 matlab
  • ¥15 求lingo代码和思路
  • ¥15 公交车和无人机协同运输
  • ¥15 stm32代码移植没反应