2016-02-19 9 views
5

ありながら、パラメータの不一致、パターンが文字列です。しかし、私はフォームのデータを更新するときにいくつかのエラーで立ち往生した。挿入、選択、削除のクエリはエラーなく正常に動作しています。以下に示すように、エラーが表示されている更新クエリを使用しながら、しかし:にpreg_replace():helpers.phpライン683にlaravel 5.2:ErrorException:にpreg_replace():交換が、私はlaravelに新しいですし、私は私の研究の目的のためにlaravel 5.2でプロジェクトをやっている配列

ErrorExceptionパラメータの不一致を交換が所定以下アレイ

in helpers.php line 683 
at HandleExceptions->handleError('2', 'preg_replace(): Parameter mismatch, pattern is a string while replacement is an array', 'F:\xampp\htdocs\multidatatechnologies.com\vendor\laravel\framework\src\Illuminate\Support\helpers.php', '683', array('search' => '\?', 'replace' => array(array('menutype' => 'Fast Food', 'status' => '1'), '2'), 'subject' => 'update `menutypes` set `0` = ? where `id` = ?', 'value' => array('menutype' => 'Fast Food', 'status' => '1'))) 
at preg_replace('/\?/', array('menutype' => 'Fast Food', 'status' => '1'), 'update `menutypes` set `0` = ? where `id` = ?', '1') in helpers.php line 683 
at str_replace_array('\?', array(array('menutype' => 'Fast Food', 'status' => '1'), '2'), 'update `menutypes` set `0` = ? where `id` = ?') in QueryException.php line 56 
at QueryException->formatMessage('update `menutypes` set `0` = ? where `id` = ?', array(array('menutype' => 'Fast Food', 'status' => '1'), '2'), object(PDOException)) in QueryException.php line 39 
at QueryException->__construct('update `menutypes` set `0` = ? where `id` = ?', array(array('menutype' => 'Fast Food', 'status' => '1'), '2'), object(PDOException)) in Connection.php line 653 
at Connection->runQueryCallback('update `menutypes` set `0` = ? where `id` = ?', array(array('menutype' => 'Fast Food', 'status' => '1'), '2'), object(Closure)) in Connection.php line 611 
at Connection->run('update `menutypes` set `0` = ? where `id` = ?', array(array('menutype' => 'Fast Food', 'status' => '1'), '2'), object(Closure)) in Connection.php line 416 
at Connection->affectingStatement('update `menutypes` set `0` = ? where `id` = ?', array(array('menutype' => 'Fast Food', 'status' => '1'), '2')) in Connection.php line 359 
at Connection->update('update `menutypes` set `0` = ? where `id` = ?', array(array('menutype' => 'Fast Food', 'status' => '1'), '2')) in Builder.php line 1904 
at Builder->update(array(array('menutype' => 'Fast Food', 'status' => '1'))) in AdminController.php line 84 
at AdminController->updatemenutype(object(Request)) 
at call_user_func_array(array(object(AdminController), 'updatemenutype'), array(object(Request))) in Controller.php line 76 
at Controller->callAction('updatemenutype', array(object(Request))) in ControllerDispatcher.php line 146 
at ControllerDispatcher->call(object(AdminController), object(Route), 'updatemenutype') in ControllerDispatcher.php line 94 
at ControllerDispatcher->Illuminate\Routing\{closure}(object(Request)) 
at call_user_func(object(Closure), object(Request)) in Pipeline.php line 52 
at Pipeline->Illuminate\Routing\{closure}(object(Request)) 
at call_user_func(object(Closure), object(Request)) in Pipeline.php line 103 
at Pipeline->then(object(Closure)) in ControllerDispatcher.php line 96 
at ControllerDispatcher->callWithinStack(object(AdminController), object(Route), object(Request), 'updatemenutype') in ControllerDispatcher.php line 54 
at ControllerDispatcher->dispatch(object(Route), object(Request), 'App\Http\Controllers\AdminController', 'updatemenutype') in Route.php line 174 
at Route->runController(object(Request)) in Route.php line 140 
at Route->run(object(Request)) in Router.php line 703 
at Router->Illuminate\Routing\{closure}(object(Request)) 
at call_user_func(object(Closure), object(Request)) in Pipeline.php line 52 
at Pipeline->Illuminate\Routing\{closure}(object(Request)) in VerifyCsrfToken.php line 64 
at VerifyCsrfToken->handle(object(Request), object(Closure)) 
at call_user_func_array(array(object(VerifyCsrfToken), 'handle'), array(object(Request), object(Closure))) in Pipeline.php line 124 
at Pipeline->Illuminate\Pipeline\{closure}(object(Request)) 
at call_user_func(object(Closure), object(Request)) in Pipeline.php line 32 
at Pipeline->Illuminate\Routing\{closure}(object(Request)) in ShareErrorsFromSession.php line 49 
at ShareErrorsFromSession->handle(object(Request), object(Closure)) 
at call_user_func_array(array(object(ShareErrorsFromSession), 'handle'), array(object(Request), object(Closure))) in Pipeline.php line 124 
at Pipeline->Illuminate\Pipeline\{closure}(object(Request)) 
at call_user_func(object(Closure), object(Request)) in Pipeline.php line 32 
at Pipeline->Illuminate\Routing\{closure}(object(Request)) in StartSession.php line 62 
at StartSession->handle(object(Request), object(Closure)) 
at call_user_func_array(array(object(StartSession), 'handle'), array(object(Request), object(Closure))) in Pipeline.php line 124 
at Pipeline->Illuminate\Pipeline\{closure}(object(Request)) 
at call_user_func(object(Closure), object(Request)) in Pipeline.php line 32 
at Pipeline->Illuminate\Routing\{closure}(object(Request)) in AddQueuedCookiesToResponse.php line 37 
at AddQueuedCookiesToResponse->handle(object(Request), object(Closure)) 
at call_user_func_array(array(object(AddQueuedCookiesToResponse), 'handle'), array(object(Request), object(Closure))) in Pipeline.php line 124 
at Pipeline->Illuminate\Pipeline\{closure}(object(Request)) 
at call_user_func(object(Closure), object(Request)) in Pipeline.php line 32 
at Pipeline->Illuminate\Routing\{closure}(object(Request)) in EncryptCookies.php line 59 
at EncryptCookies->handle(object(Request), object(Closure)) 
at call_user_func_array(array(object(EncryptCookies), 'handle'), array(object(Request), object(Closure))) in Pipeline.php line 124 
at Pipeline->Illuminate\Pipeline\{closure}(object(Request)) 
at call_user_func(object(Closure), object(Request)) in Pipeline.php line 32 
at Pipeline->Illuminate\Routing\{closure}(object(Request)) 
at call_user_func(object(Closure), object(Request)) in Pipeline.php line 103 
at Pipeline->then(object(Closure)) in Router.php line 705 
at Router->runRouteWithinStack(object(Route), object(Request)) in Router.php line 678 
at Router->dispatchToRoute(object(Request)) in Router.php line 654 
at Router->dispatch(object(Request)) in Kernel.php line 246 
at Kernel->Illuminate\Foundation\Http\{closure}(object(Request)) 
at call_user_func(object(Closure), object(Request)) in Pipeline.php line 52 
at Pipeline->Illuminate\Routing\{closure}(object(Request)) in CheckForMaintenanceMode.php line 44 
at CheckForMaintenanceMode->handle(object(Request), object(Closure)) 
at call_user_func_array(array(object(CheckForMaintenanceMode), 'handle'), array(object(Request), object(Closure))) in Pipeline.php line 124 
at Pipeline->Illuminate\Pipeline\{closure}(object(Request)) 
at call_user_func(object(Closure), object(Request)) in Pipeline.php line 32 
at Pipeline->Illuminate\Routing\{closure}(object(Request)) 
at call_user_func(object(Closure), object(Request)) in Pipeline.php line 103 
at Pipeline->then(object(Closure)) in Kernel.php line 132 
at Kernel->sendRequestThroughRouter(object(Request)) in Kernel.php line 99 
at Kernel->handle(object(Request)) in index.php line 54 

あるが、パターンは、文字列であります更新用フォーム(editmenutype.blade.php)のビューファイルのために私が書いたコードされています。与えられた以下

<form class="form-horizontal" method="post" action="{{action('[email protected]')}}"> 
      <input type="hidden" name="_token" value="{{csrf_token()}}" /> 
      <input type="hidden" name="eid" value="{{$row->id}}" />       
       <div class="box-body"> 
       <label>Menu-Type Name:</label> 
       <div class="input-group"> 
        <div class="input-group-addon"> 
        <i class="fa fa-fire"></i> 
        </div> 
      <input type="text" name="menutype" class="form-control" value="{{$row->menutype}}" placeholder="Enter Menu-Type Name..." required="required" maxlength="100"> 
       </div><!-- /.input group --> 
       </div><!-- /.form group -->  
       <div class="box-body"> 
       <label>Publishing Status:</label> 
       <div class="input-group"> 
        <div class="input-group-addon"> 
        <i class="fa fa-globe"></i> 
        </div> 
        <select name="status" class="form-control" style="width: 100%;" required="required"> 
         <option value="{{$row->status}}" disabled="disabled"><?php if($row->status==1){echo "Yes"; }else{echo "No";} ?></option>       
         <option value="1">Yes</option> 
         <option value="0">No</option> 
        </select> 
       </div><!-- /.input group --> 
       </div><!-- /.form group -->      
       <div class="box-footer"> 
        <input type="reset" name="reset" class="btn btn-default" value="Cancel"> 
        <input type="submit" name="submit" class="btn btn-info pull-right" value="Edit Menu-Type"> 
       </div> 
       </form> 

は、データを更新するためのコントローラで書かれた私の対応機能(AdminController.php)です。

与えられた以下
public function editmenutype($id) { 
    $row = DB::table('menutypes')->where('id',$id)->first(); 
    return view('admin.editmenutype')->with('row',$row); 
} 

public function updatemenutype(Request $request) { 
    $post=$request->all(); 
    print_r($post); 
    //var_dump($post); 
    $v=\Validator::make($request->all(), 
    [ 
     'menutype' => 'required', 
     'status' => 'required', 
    ]); 
    if($v->fails()) 
    { 
     return redirect()->back()->withErrors($v->errors()); 
    } 
    else 
    { 
     $data = array(
     [ 
      'menutype' => $post['menutype'], 
      'status' => $post['status'], 
     ]); 
     $i = DB::table('menutypes')->where('id',$post['eid'])->update($data); 
     if($i > 0) 
     { 
      \Session::flash('message','* Menu-Type Updated Successfully.'); 
      return redirect('/admin/managemenutypes'); 
     } 
    } 
} 

は、私は、ルートファイル(routes.phpの)対応するページを呼び出すために与えられ、対応するコードです:

Route::get('admin/editmenutype/{id}','[email protected]'); 
Route::post('admin/updatemenutype','[email protected]'); 

なぜ更新クエリのみの場合に発生し、このエラー?この問題を解決するための安定した正しい方法で私を助けてください...事前に感謝します。あなたのAdminController.php

答えて

2

array() and \[\] are both declarations of an empty array.

、以下を参照してください

public function updatemenutype(Request $request) { 
    ... 
    if($v->fails()) 
    { 
     return redirect()->back()->withErrors($v->errors()); 
    } 
    else 
    { 
     //Error is here: array within array 
     $data = array(
     [ 
      'menutype' => $post['menutype'], 
      'status' => $post['status'], 
     ]); 
    ...   
} 

を代わりに、それは次のようになります。

public function updatemenutype(Request $request) { 
    ... 
    if($v->fails()) 
    { 
     return redirect()->back()->withErrors($v->errors()); 
    } 
    else 
    { 
     //Single array declaration 
     $data = 
     [ 
      'menutype' => $post['menutype'], 
      'status' => $post['status'], 
     ]; 
    ...   
} 
+0

はい。どうもありがとう。それは今、完璧に働いた。しかし、挿入クエリの場合にも私は配列内の配列として与えていた、それは完全に動作します。それで、なぜ配列内に配列として与えるとき、それは更新クエリのために機能しませんでしたか? –

+1

照明文法クラス( 'Illuminate \ Database \ Query \ Grammars \ Grammar')を調べると、値配列を暗示する' parameterize'関数を使って挿入が行われます。一方、update関数は 'name = value'の形式で文字列を作成します。したがって、配列内の配列は更新中に' 0 = array'になります。したがって、クラッシュします。 – Mysteryos

+0

oh。はいはい。この問題についての説明をいただきありがとうございます。 –

関連する問題