Mysql
 sql >> Base de données >  >> RDS >> Mysql

Comment écrire où entre la requête dans yii2

Peut-être un problème lié à la conversion de l'entrée essayez d'utiliser un str_to_date et un littéral Where(utilisez une conversion de format de date appropriée basée sur votre format im my sample is "%d-%m-%Y")

$modelStockDetails=StockDetails::find()
  ->where(' date(created) between STR_TO_DATE("'.  $start_date . '", "%d-%m-%Y" ) 
        AND   STR_TO_DATE("' .  $end_date . '", "%d-%m-%Y" )' )
  ->andwhere(['receiving_order_id' =>$modelRecevingOrder->id,'deleted' => 'N'])->all();

ou pour éviter l'utilisation de var en sql, vous pouvez utiliser

$modelStockDetails=StockDetails::find()
->where(' date(created) between STR_TO_DATE(:start_date, "%d-%m-%Y" ) 
      AND   STR_TO_DATE( :end_date, "%d-%m-%Y" )', [':start_date' => $start_date, ':end_date' => $end_date] )
->andwhere(['receiving_order_id' =>$modelRecevingOrder->id,'deleted' => 'N'])->all();