跨多个表的phalcon模型条件

时间:2015-08-09 14:10:01

标签: php mysql model-view-controller phalcon

我是phalcon和mvc的新手所以请耐心等待。

我有两个表,媒体和用户,分别是媒体和用户模型。代码

use Phalcon\Mvc\Model;        
class Media extends Model
        {

            public $media_id, $user, $media_type, $title, $status_on, $visible, $modified_date;

            public function initialize()
            {
                $this->belongsTo('user', 'users', 'user_id');
            }
        }
use Phalcon\Mvc\Model;        
class Users extends Model
    {
        public $user_id, $first_name, $last_name, $email_address, $status, $created_on;

        public function initialize()
        {
             $this->hasMany('user_id','media','user');
    }
}

我想使用以下条件检索

"title LIKE '%just a text%' AND status_on='P' AND media_type=4 AND status='A'";

这是通过控制器方法来访问媒体模型

$medium = media::find(array( "conditions" =>$conditions,
                "ORDER" => "modify_date DESC"));

我一直收到此错误

Column 'status' doesn't belong to any of the selected models (1), when preparing: SELECT [Media].* FROM [Media] WHERE title LIKE '%just a text%' AND status_on='P' AND status='A'

任何人都可以帮忙吗?我基本上想要根据2个表中的条件检索记录,这些表通常以

的形式编写
SELECT * FROM media a, users b, WHERE a.user=b.user_id AND a.title LIKE '%just a text%' AND a.status_on='P' AND a.media_type=4 AND b.status='A'

感谢。

2 个答案:

答案 0 :(得分:0)

您必须使用查询构建器来获得所需的结果:我在下面创建了一个您可能需要修改的示例 - 我不确定我是否在连接方法中更正了连接列。< / p>

$media = $this->modelsManager->createBuilder()
    ->from('Media')
    ->join('Users', 'Media.media_id = Users.user_id', 'u')
    ->where("title LIKE '%just a text%'")
    ->andWhere("status_on='P'")
    ->andWhere("media_type=4")
    ->andWhere("u.status='A'")
    ->getQuery()
    ->execute();

如需进一步说明,请参阅文档:https://docs.phalconphp.com/en/latest/reference/phql.html#creating-queries-using-the-query-builder

答案 1 :(得分:0)

也可以通过使用子查询进行过滤来实现。 这可能不是最优雅的方式,但确实可以。

Media::find([
    'conditions' => "title LIKE '%just a text%' AND status='A' AND user_id IN (SELECT user FROM [Media] WHERE [Users].user_id = user AND media_type=4)"
]);

请记住方括号,如果您的模型有命名空间,您应该提供完整路径,例如 [ACME\Models\Media].user_id