首先我解释我的问题:
我有两张表 Job 和 JobCategory :
job:
-------------------------------------------------
| id | category_job_id | job_name | keywords |
-------------------------------------------------
JobCategory:
-------------------------
| id | categoty_name |
-------------------------
这两个表通过外键“category_job_id”相关。
在这个应用程序中,我使用 Propel ORM。我希望使用三个字段关键字 job_name 和 category_name 进行搜索。
第一个字段是keywords是“输入”谁我可以写关键字,第二个字段是Category_name是一个“选择”,类别列表。第三个字段是 Job_name 并且是一个“选择”,作业名称列表,如果不为空,则关键字字段将被忽略。
我做这样的搜索功能,但它对我不起作用:
public function searchFilter($job,$category,$keyword)
{
$order = isset($this->order) ? $this->order : Criteria::ASC;
$job = '%' .$job. '%';
$category = '%' .$category. '%';
$c = new Criteria();
$c->addJoin(JobPeer::CATEGORY_JOB_ID, JobCategoryPeer::ID);
if((null !== $category) AND ($category !== ""))
{
$c->addOr(JobCategoryPeer::CATEGORY_NAME,$category, Criteria::LIKE);
}
if((null !== $job) AND ($job !== ""))
{
$c->addOr(JobPeer::JOB_NAME,$job, Criteria::LIKE);
}
$query = JobQuery::create(null, $c)
->joinWith('Job.JobCategory')
->orderByDateOfJob($order);
if((null !== $keyword) AND ($keyword !== "")){
$keyword = '%' .$keyword. '%';
$query->filterByKeywords($keyword, Criteria::LIKE);
}
$results = $query->find();
return $results;
}
但是搜索是所有情况都是错误的!