关于子查询

大家都知道PHP中是不能用子查询的

但我现在有个想法就是:
有一个人力资源管理系统,它的查询条件非常的挑剔和不定的
所以我有必要一个一个条件来查询筛选出符合要求的记录,
那么在SQL SERVER中就可以用子查询来做先生成一个结果集
再在这个结果集上筛选,,
在PHP要实现这样的功能应该怎么做??

作者: Mickey   发布时间: 2003-07-05

waiting on line

作者: Mickey   发布时间: 2003-07-05

这个不是php的问题,你去mysql.com下载mysql 410版,支持子查询,当然是个alpha版的,good luck

如果用老版本呢,用一些临时表就可以,当然有些查询可以通过复杂的语句完成,具体参看mysql reference manual

作者: Belltree   发布时间: 2003-07-05



QUOTE:
最初由 Belltree 发布
[B]这个不是php的问题,你去mysql.com下载mysql 410版,支持子查询,当然是个alpha版的,good luck

如果用老版本呢,用一些临时表就可以,当然有些查询可以通过复杂的语句完成,具体参看mysql reference manual [/B]
thanks
那些临时表是怎么用的?
举个例子来看看

作者: Mickey   发布时间: 2003-07-05

阿BELLTREE哥,帮个忙啊

作者: Mickey   发布时间: 2003-07-05

waiting on line

作者: Mickey   发布时间: 2003-07-05

You can often rewrite the query without a subquery:

SELECT * FROM table1 WHERE id IN (SELECT id FROM table2);

This can be rewritten as:

SELECT table1.* FROM table1,table2 WHERE table1.id=table2.id;

The queries:

SELECT * FROM table1 WHERE id NOT IN (SELECT id FROM table2);
SELECT * FROM table1 WHERE NOT EXISTS (SELECT id FROM table2
                                       WHERE table1.id=table2.id);

Can be rewritten as:

SELECT table1.* FROM table1 LEFT JOIN table2 ON table1.id=table2.id
                                       WHERE table2.id IS NULL;

作者: Belltree   发布时间: 2003-07-05

谢谢,解决了

作者: alangcry   发布时间: 2003-09-08