web-dev-qa-db-ja.com

2つの日付間のクエリのCakePHPの検索条件

データベースに開始日と終了日、フォームフィールドの$ date変数があります。 $ dateがデータベースの開始/終了日、またはこれら2つの間の任意の日付であるすべての行をクエリしようとしています。

これは、daysAsSqlがどのように機能するかのドキュメントで説明されているものとは正反対です。どうやって動かすのか分かりません。次の行は、コントローラーの検索条件として機能しません。

'? BETWEEN ? AND ?' => array($date, 'Item.date_start', 'Item.date_end'),

どんな助けでも大歓迎です。これは私を夢中にさせています。

次に、完全なクエリと対応するSQLを示します。

$conditions = array(
            'conditions' => array(
            'and' => array(
                '? BETWEEN ? AND ?' => array($date, 'Item.date_start', 'Item.date_end'),
                'Item.title LIKE' => "%$title%",
                'Item.status_id =' => '1'
                )));

        $this->set('items', $this->Item->find('all', $conditions));



WHERE (('2012-10-06' BETWEEN 'Item.date_start' AND 'Item.date_end') AND (`Item`.`title` LIKE '%%') AND (`Item`.`status_id` = 1))
11
Joshua
$conditions = array(
        'conditions' => array(
        'and' => array(
                        array('Item.date_start <= ' => $date,
                              'Item.date_end >= ' => $date
                             ),
            'Item.title LIKE' => "%$title%",
            'Item.status_id =' => '1'
            )));

上記のコードを試して、うまくいかなかったかどうか尋ねてください。

編集: @Aryanのリクエストに従って、1か月間に登録されたユーザーを見つける必要がある場合:

$start_date = '2013-05-26'; //should be in YYYY-MM-DD format
$this->User->find('all', array('conditions' => array('User.reg_date BETWEEN '.$start_date.' AND DATE_ADD('.$start_date.', INTERVAL 30 DAY)')));
28
Arun Jain

ここは CakePHP BETWEENクエリの例。

配列を変数として定義し、それらの変数をCakePHPのfind関数呼び出しで使用しています。

// just return these two fields
$fields = array('uri', 'page_views');

// use this "between" range
$conditions = array('Event.date BETWEEN ? and ?' => array($start_date, $end_date));

// run the "select between" query
$results = $this->Event->find('all', 
         array('fields'=>$fields, 
               'conditions'=>$conditions));

参照元

4
Aditya P Bhatt

CakePHP 2.xクエリの一般的な例

        $_condition = array("TABLENAME.id" => $id, "TABLENAME.user_id" => array_unique($_array), 'date(TABLENAME.created_at) BETWEEN ? AND ?' => array($start_date, $end_date));
        $result_array = $this->TABLENAME->find("all", array(
            'fields' => array("TABLENAME.id", "TABLENAME.user_id", 'TABLENAME.created_at'),
            "conditions" => $_condition,
            "group" => array("TABLENAME.id"), //fields to GROUP BY
            'joins' => array(
                array(
                    'alias' => 'T2',
                    'table' => 'TABLENAME2',
                    'type' => 'LEFT',
                    'conditions' => array('TABLENAME.t_id = TABLENAME2.t_id')
                ),
                array(
                    'alias' => 'T3',
                    'table' => 'TABLENAME3',
                    'type' => 'LEFT',
                    'conditions' => array(
                        'IF(
                           TABLENAME.t3_id > 0,
                                T2.f_id = T3.f_id,
                                TABLENAME.ff_id = T2.ff_id
                            )'
                    )
                ),
            ),
            'recursive' => 0
                )
        );
0
Abdul Rehman
$data=$this->post->find('all')->where([ 'id'=>$id,
'price between'=>$price1,'and'=>$price2])->toArray();

このクエリは次のように機能します。

select * from post where id=$id and price between $price1 and $price2;

"-'price between' => $ price1-"は "price between $ price1"になります

0
Riyaz Khan

これはより効率的で理解しやすいIN BETWEENクエリcakephp 2.x

$testing_log_device_site_name = $testingLogData['TestingLogDevice']['Siteid'];

$conditions = array('TestingLogDevice.dateee BETWEEN ? and ?' => array($start_date, $end_date));

$results = $this->TestingLogDevice->find('all', 
    array(
         'fields'=>array('dateee','timeee','Siteid'), 
         'conditions'=>array($conditions, 'TestingLogDevice.Siteid'=>$testing_log_device_site_name)
    )
);
pr($results);
0
A.A Noman