Mysql
 sql >> Datenbank >  >> RDS >> Mysql

Wie schreibt man where Between Abfrage in yii2

Könnte ein Problem im Zusammenhang mit der Konvertierung der Eingabe sein, versuchen Sie es mit einem str_to_date und einem wörtlichen Where (verwenden Sie eine geeignete Datumsformatkonvertierung basierend auf Ihrem Format, im Beispiel ist "%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();

oder um die Verwendung von var in SQL zu vermeiden, könnten Sie

verwenden
$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();