2017-04-12 75 views
1

我有一個函數,我插入recort給db.But當我執行此函數時,我收到消息SQLSTATE [42S22]:列不是發現:1054未知列 '0' '字段列表'未找到列:1054 Laravel的'字段列表'中的未知列'0'

Message

Database

我的控制器功能

public function postCheckout(Request $request){ 
    if(!Session::has('cart')){ 
     return view('cart.shopping_cart'); 
    } 
    $data = $request->all(); 
    $oldCart=Session::get('cart'); 
    $cart=new Cart($oldCart);  
    $order=new Order(); 
    $order->order_code="Order00006"; 
    $order->user_id=Auth::user()?Auth::user()->id:1; 
    $order->full_name=$data['full_name']; 
    $order->phone=$data['phone']; 
    $order->address=$data['address']; 
    $order->recieve_address=$data['recieve_address']; 
    $order->total_product=$cart->totalQuantity; 
    $order->total_price=$cart->totalPrice;  
    $orderArr=array($order); 
    Order::insert($orderArr); 
} 

在模型

class Order extends Model 
{ 
    protected $table="orders"; 
    protected $fillable = [ 
    'order_code','user_id','full_name','phone', 'address', 'recieve_address', 'total_product','total_price' , 
    ]; 
    public function user(){ 
     return $this->belongsTo('App\User'); 
    } 
} 

我怎麼能解決這個問題?

回答

1

使用保存功能,而不是插入

public function postCheckout(Request $request){ 
if(!Session::has('cart')){ 
    return view('cart.shopping_cart'); 
} 
$data = $request->all(); 
$oldCart=Session::get('cart');  
$order=new Order(); 
$order->order_code="Order00006"; 
$order->user_id=Auth::user()?Auth::user()->id:1; 
$order->full_name=$data['full_name']; 
$order->phone=$data['phone']; 
$order->address=$data['address']; 
$order->recieve_address=$data['recieve_address']; 
$order->total_product=$oldCart->totalQuantity; 
$order->total_price=$oldCart->totalPrice;  
$order->save(); 
echo "Data saved"; die; 
} 
+0

所以,如果我想多保存記錄數據庫,我怎麼能與保存方法EXCUTE? – John

+1

是的@john完全插入也將工作,但你閱讀laravel 5.2 – kunal

+1

的文檔謝謝@kunal,我正在讀它 – John

相關問題