亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何使用 DB::Tranactions 將數據插入單個控制器中的兩個表

如何使用 DB::Tranactions 將數據插入單個控制器中的兩個表

PHP
鴻蒙傳說 2022-07-02 16:48:37
我想注冊一個用戶并將數據插入到帳戶表中,并將帳戶的 user_id 作為創建的用戶 ID 插入,我從我的管理控制器中執行此操作;public function store(StoreUsersRequest $request)    {        DB::transaction(function($request)        {            $newUser = User::create($request->all());            $newAccounts = Accounts::create([                'user_id' => $newUser->id,                'balance' => '0',                'amt' => '0',            ]);            if( !$newAccounts )            {                throw new \Exception('accounts not created for new user');            }        });        return redirect()->route('users.create');    } 任何人都可以告訴我怎么做嗎?
查看完整描述

2 回答

?
猛跑小豬

TA貢獻1858條經驗 獲得超8個贊

試試這個代碼。我假設你的表名是“accounts”


$result = DB::transaction(function () use ($request) {

  $data = new User;

  $data->name = $request->name;

  $data->other_values = $request->values;

  $data->save();

  DB::table('accounts')->insert(['user_id' => $data->id, 'balance' =>  '0', 'amount' => '0']);

  return true;

}, 5);


if($result) {

  // Redirect after successful execution

  return redirect()->route('users.create');

} else {

  // Redirect after unsuccessful execution

  Session::flash('failed','Oops, accounts not created for new user');

  return redirect()->route('previous.route');

}

在查看文件中


@if (session('failed'))

  <div class="alert alert-danger">

    {{ session('failed') }}

  </div>

@endif


查看完整回答
反對 回復 2022-07-02
?
烙印99

TA貢獻1829條經驗 獲得超13個贊

try {

    DB::beginTransaction();


    $newUser = User::create($request->all());


    $newAccounts = Accounts::create([

        'user_id' => $newUser->id,

        'balance' => '0',

        'amt' => '0',

    ]);


    DB::commit();

} catch (\Exception $e) {

    DB::rollback();


    throw new \Exception('accounts not created for new user');

}


查看完整回答
反對 回復 2022-07-02
  • 2 回答
  • 0 關注
  • 103 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號