19

Laravel で POST を介して基本的なレコードを更新するのに問題があります。

すべての投稿データを配列にキャプチャしました。既存の Order# が 0 の場合は、新しいレコードを作成します (正常に動作します)。それ以外の場合は、既存のレコードを更新します。

Order.php

class Order extends Eloquent {
    public static $table = 'my_orders';
}

Routes.php

//Handle a new order POST
Route::post('order', array('do' => function() {
    $thisOrder = array(
         'qty' => Input::get('quantity'),
         'desc' => Input::get('description'),
    );

    $thisOrderID = Input::get('orderNo');

    //CHECK FOR NEW OR EXISTING ORDER
    if($thisOrderID > 0) {
        //THIS FUNCTION SOMEHOW RETURNS THE FUNCTION CALL AND DOESNT CONTINUE PAST
        //AND THE RECORD IS NOT UPDATED
        $updateOrder = Order::update($thisOrderID, $thisOrder);
    }
}

更新: 上記のコードは実際に機能します。検証エラーが発生したため、関数が早期に返されていました。

4

3 に答える 3

25

この行の代わりに:

$updateOrder = Order::update($thisOrderID, $thisOrder);

あなたがする必要があります:

$updateOrder = Order::find($thisOrderID)->update($thisOrder);

find() (where_id() と同じ) を使用してデータベースから特定の行を選択し、update を使用して新しいデータを渡します。

于 2012-12-03T15:11:13.193 に答える
3

これについてどう思いますか:

//Handle a new order POST
Route::post('order', array('do' => function() {
    $thisOrder = array(
         'qty' => Input::get('quantity'),
         'desc' => Input::get('description'),
    );

    $thisOrderID = Input::get('orderNo');

    $order = Order::find( $thisOrderID );

    //CHECK FOR NEW OR EXISTING ORDER
    if( $order ) {
        $order->title = 'New order title';
        $order->desc = 'New description';
        $order->save();
    }
}
于 2012-12-03T15:10:03.233 に答える
1

$thisOrder にキーが含まれている場合はレコードが更新され、そうでない場合は新しいレコードが作成されます。

$thisOrder = array(
     'orderNo' => Input::get('orderNo'),
     'qty' => Input::get('quantity'),
     'desc' => Input::get('description'),
);

$updateOrder = Order::save($thisOrder);

if Input::get('orderNo') 値は作成されません else 更新

于 2012-12-04T10:13:26.753 に答える