dongzong1866 2012-07-16 15:11
浏览 13

一个mysql操作中的三个WHERE语句可以作为更好的过滤器吗?

I'm trying to compare two tables and work on a result of this operation.

SELECT * FROM table1
WHERE table1.czlowiek_id NOT IN (
    SELECT table2.czlowiek_id
    FROM table2
    WHERE table1.czlowiek_id=table2.czlowiek_id
)  
OR table1.czlowiek_id IN (
    SELECT table2.czlowiek_id
    FROM table2
    WHERE table1.czlowiek_id=table2.czlowiek_id
    AND table2.szkolenie_id IN ('$selected_one')
    AND table1.instruktor IN ('$selected_two')
) 

Is there some option to work on a result from this query adding another WHERE statement?

  • 写回答

3条回答 默认 最新

  • dongyuan1160 2012-07-16 15:21
    关注

    You may be able to solve the problem with a LEFT JOIN. This will allow you to pull all of the results from table1 that don't exist in table2, AND pull the results from table1 that are in table2 and match the requested filters.

    SELECT
        *
    FROM
        table1
        LEFT JOIN table2 ON table1.czlowiek_id=table2.czlowiek_id
    WHERE
        table2.czlowiek_id IS NULL
        OR (
            table2.szkolenie_id IN ('$selected_one')
            AND table1.instruktor IN ('$selected_two')
        )
    
    评论

报告相同问题?

悬赏问题

  • ¥15 无线电能传输系统MATLAB仿真问题
  • ¥50 如何用脚本实现输入法的热键设置
  • ¥20 我想使用一些网络协议或者部分协议也行,主要想实现类似于traceroute的一定步长内的路由拓扑功能
  • ¥30 深度学习,前后端连接
  • ¥15 孟德尔随机化结果不一致
  • ¥15 apm2.8飞控罗盘bad health,加速度计校准失败
  • ¥15 求解O-S方程的特征值问题给出边界层布拉休斯平行流的中性曲线
  • ¥15 谁有desed数据集呀
  • ¥20 手写数字识别运行c仿真时,程序报错错误代码sim211-100
  • ¥15 关于#hadoop#的问题