我想在Zend_Db中生成这个复杂的WHERE子句:
SELECT * 
FROM 'products' 
WHERE 
    status = 'active' 
    AND 
    (
        attribute = 'one' 
        OR 
        attribute = 'two' 
        OR 
        [...]
    )
;
我试过这个:
$select->from('product');
$select->where('status = ?', $status);
$select->where('attribute = ?', $a1);
$select->orWhere('attribute = ?', $a2);
那产生了:
SELECT `product`.* 
FROM `product` 
WHERE 
    (status = 'active') 
    AND 
    (attribute = 'one') 
    OR 
    (attribute = 'two')
;
我确实找到了一种方法来完成这项工作,但我觉得通过先使用PHP组合"OR"子句然后使用Zend_Db where()子句将它们组合起来,这有点"作弊".PHP代码:
$WHERE = array();
foreach($attributes as $a):
    #WHERE[] = "attribute = '" . $a . "'";
endforeach;
$WHERE = implode(' OR ', $WHERE);
$select->from('product');
$select->where('status …这应该是非常直接的,但我似乎无法让它工作,尽管通过谷歌,Stackoverflow和手册页阅读了几个教程.
我创建了一个每1分钟运行一次的cron(用于测试),所有它基本上都是吐出日期.
crontab -l
* * * * * /var/test/cron-test.sh
cron-test文件是:
echo "$(date): cron job run" >> test.log
等待很多分钟,我从未看到过test.log文件.
我可以手动调用"test.sh"并将其输出并追加.
我想知道我错过了什么?我也是这样做的.我想知道我是否错过了解根的位置?我的路径搞砸了,因为它附加了某种主目录吗?
谢谢!
更新-----------------
看来我没有跟踪目录路径.如果我将目录更改为root的主目录:
# cd
我看到我的输出文件"test.log",每分钟打印出所有日期.
所以,我会更新我的问题,我错过了什么 - 理解/路径?我需要使用一个术语来从根目录开始吗?
干杯!
更新2 -----------------
好的,所以我得到了我所缺少的东西.
设置crontab的脚本工作正常.它找到了相对于根目录的文件.即:
* * * * * /var/test/cron-test.sh
但是"cron-test.sh"文件没有相对于根目录设置.因此,当"root"运行脚本时,它会将其转储回"root"的主目录.我的想法是,由于脚本在"/ var/test /"中运行,文件也会被转储到"/ var/test /"中.
相反,我需要在脚本文件中设置位置以正确地转储它.
echo "$(date): cron job run" >> /var/test/test.log
这很有效.