![](/img/trans.png)
[英]How to get last inserted non incremental id using eloquent in Laravel?
[英]Get the Last Inserted Id Using Laravel Eloquent
我目前正在使用以下代码在表中插入数据:
<?php
public function saveDetailsCompany()
{
$post = Input::All();
$data = new Company;
$data->nombre = $post['name'];
$data->direccion = $post['address'];
$data->telefono = $post['phone'];
$data->email = $post['email'];
$data->giro = $post['type'];
$data->fecha_registro = date("Y-m-d H:i:s");
$data->fecha_modificacion = date("Y-m-d H:i:s");
if ($data->save()) {
return Response::json(array('success' => true), 200);
}
}
我想返回最后插入的 ID,但我不知道如何获取它。
亲切的问候!
在save之后, $data->id
应该是最后插入的 id。
$data->save();
$data->id;
可以这样使用。
return Response::json(array('success' => true, 'last_insert_id' => $data->id), 200);
对于更新的 Laravel 版本试试这个
return response()->json(array('success' => true, 'last_insert_id' => $data->id), 200);
xdazz在这种情况下是正确的,但为了将来可能使用DB::statement
或DB::insert
访问者的利益,还有另一种方法:
DB::getPdo()->lastInsertId();
对于那些也喜欢 Jeffrey Way 在他的 Laracasts 5 教程中如何使用Model::create()
,他只是将请求直接发送到数据库中,而没有明确设置控制器中的每个字段,并使用模型的$fillable
进行批量分配(非常重要,对于任何新手和使用这种方式的人):我读了很多人使用insertGetId()
但不幸的是这不尊重$fillable
白名单,所以你会在尝试插入 _token 和任何不是的时候出错数据库中的一个字段,最终设置要过滤的内容等。这让我很沮丧,因为我想使用批量分配并在可能的情况下整体编写更少的代码。 幸运的是,Eloquent 的create
方法只是包装了 save 方法(上面引用的@xdazz),所以你仍然可以拉取最后创建的 ID...
public function store() {
$input = Request::all();
$id = Company::create($input)->id;
return redirect('company/'.$id);
}
如果表有自动递增的 id,则使用 insertGetId 方法插入一条记录,然后检索该 ID:
$id = DB::table('users')->insertGetId([
'email' => 'john@example.com',
'votes' => 0
]);
**** 对于 Laravel ****
首先创建一个对象,然后为该对象设置属性值,然后保存对象记录,然后获取最后插入的id。 如
$user = new User();
$user->name = 'John';
$user->save();
// 现在获取最后插入的 id
$insertedId = $user->id;
echo $insertedId ;
在laravel 5:你可以这样做:
use App\Http\Requests\UserStoreRequest;
class UserController extends Controller {
private $user;
public function __construct( User $user )
{
$this->user = $user;
}
public function store( UserStoreRequest $request )
{
$user= $this->user->create([
'name' => $request['name'],
'email' => $request['email'],
'password' => Hash::make($request['password'])
]);
$lastInsertedId= $user->id;
}
}
这在 Laravel 4.2 中对我有用
$id = User::insertGetId([
'username' => Input::get('username'),
'password' => Hash::make('password'),
'active' => 0
]);
下面是一个例子:
public static function saveTutorial(){
$data = Input::all();
$Tut = new Tutorial;
$Tut->title = $data['title'];
$Tut->tutorial = $data['tutorial'];
$Tut->save();
$LastInsertId = $Tut->id;
return Response::json(array('success' => true,'last_id'=>$LastInsertId), 200);
}
使用insertGetId
同时插入和获取插入的id
来自文档
如果表有自动递增的 id,则使用 insertGetId 方法插入一条记录,然后检索该 ID:
按Model
$id = Model::insertGetId(["name"=>"Niklesh","email"=>"myemail@gmail.com"]);
由DB
$id = DB::table('users')->insertGetId(["name"=>"Niklesh","email"=>"myemail@gmail.com"]);
这是我们如何在 Laravel 4 中获取最后插入的 id
public function store()
{
$input = Input::all();
$validation = Validator::make($input, user::$rules);
if ($validation->passes())
{
$user= $this->user->create(array(
'name' => Input::get('name'),
'email' => Input::get('email'),
'password' => Hash::make(Input::get('password')),
));
$lastInsertedId= $user->id; //get last inserted record's user id value
$userId= array('user_id'=>$lastInsertedId); //put this value equal to datatable column name where it will be saved
$user->update($userId); //update newly created record by storing the value of last inserted id
return Redirect::route('users.index');
}
return Redirect::route('users.create')->withInput()->withErrors($validation)->with('message', 'There were validation errors.');
}
对于插入()
例子:
$data1 = array(
'company_id' => $company_id,
'branch_id' => $branch_id
);
$insert_id = CreditVoucher::insert($data1);
$id = DB::getPdo()->lastInsertId();
dd($id);
有几种方法可以获取最后插入的 id。 一切都基于您在插入时使用的方法。 在您的情况下,您可以获得如下所示的最后一个 ID:
$data->save();
$data->id;
对于需要知道如果他们使用其他插入方法如何获得最后插入的 id 的其他人,方法如下:
使用create()
方法
$book = Book::create(['name'=>'Laravel Warrior']);
$lastId = $book->id;
使用insertGetId()
$id = DB::table('books')->insertGetId( ['name' => 'Laravel warrior'] ); $lastId = $id;
使用lastInsertId()
方法
$lastId = DB::getPdo()->lastInsertId();
参考https://easycodesolution.com/2020/08/22/last-inserted-id-in-laravel/
保存模型后,初始化的实例具有 id:
$report = new Report();
$report->user_id = $request->user_id;
$report->patient_id = $request->patient_id;
$report->diseases_id = $request->modality;
$isReportCreated = $report->save();
return $report->id; // this will return the saved report id
虽然这个问题有点过时了。 我的快速而肮脏的解决方案如下所示:
$last_entry = Model::latest()->first();
但我想它很容易受到频繁访问的数据库的竞争条件的影响。
在 Laravel 5.2 中,我会使其尽可能干净:
public function saveContact(Request $request, Contact $contact)
{
$create = $contact->create($request->all());
return response()->json($create->id, 201);
}
后
$data->save()
$data->id
会给你插入的 id,
注意:如果您的自动增量列名称是sno那么您应该使用$data->sno
而不是$data->id
你可以这样做:
$result=app('db')->insert("INSERT INTO table...");
$lastInsertId=app('db')->getPdo()->lastInsertId();
您可以轻松获取最后插入的记录 ID
$user = User::create($userData);
$lastId = $user->value('id');
从数据库中最后插入的记录中获取 Id 是一个很棒的技巧。
节省数据库中的记录后,您可以通过访问ID $data->id
return Response::json(['success' => true, 'last_insert_id' => $data->id], 200)
对于 Laravel,如果你插入一条新记录并调用$data->save()
这个函数会执行一个 INSERT 查询并返回主键值(即默认的id )。
您可以使用以下代码:
if($data->save()) {
return Response::json(array('status' => 1, 'primary_id'=>$data->id), 200);
}
$objPost = new Post;
$objPost->title = 'Title';
$objPost->description = 'Description';
$objPost->save();
$recId = $objPost->id; // If Id in table column name if other then id then user the other column name
return Response::json(['success' => true,'id' => $recId], 200);
获取数据库中最后插入的 id 您可以使用
$data = new YourModelName;
$data->name = 'Some Value';
$data->email = 'abc@mail.com';
$data->save();
$lastInsertedId = $data->id;
这里 $lastInsertedId 会给你最后插入的自动增量 id。
最短的方法可能是在模型上调用refresh()
:
public function create(array $data): MyModel
{
$myModel = new MyModel($dataArray);
$myModel->saveOrFail();
return $myModel->refresh();
}
你也可以这样试试:
public function storeAndLastInrestedId() {
$data = new ModelName();
$data->title = $request->title;
$data->save();
$last_insert_id = $data->id;
return $last_insert_id;
}
这就是它对我的工作方式,family_id 是具有自动增量的主键我正在使用 Laravel7
public function store(Request $request){
$family = new Family();
$family->family_name = $request->get('FamilyName');
$family->family_no = $request->get('FamilyNo');
$family->save();
//family_id is the primary key and auto increment
return redirect('/family/detail/' . $family->family_id);
}
同样在扩展模型的模型族文件中,应该将增量设置为 true 否则上面的 $family-->family_id 将返回空
public $incrementing = true;
保存$data->save()
。 所有数据都被推入$data
。 由于这是一个对象,并且当前行最近刚刚保存在$data
。 所以最后一个insertId
将在$data->id
。
响应代码将是:
return Response::json(array('success' => true, 'last_insert_id' => $data->id), 200);
使用 Eloquent 模型
$user = new Report();
$user->email= 'johndoe@example.com';
$user->save();
$lastId = $user->id;
使用查询生成器
$lastId = DB::table('reports')->insertGetId(['email' => 'johndoe@example.com']);
可选方法是:
$lastID = DB::table('EXAMPLE-TABLE')
->orderBy('id', 'desc')
->first();
$lastId = $lastProduct->id;
您可以使用调用 save 方法的相同对象获取最后插入的 id;
$data->save();
$inserted_id = $data->id;
所以你可以简单地写:
if ($data->save()) {
return Response::json(array('success' => true,'inserted_id'=>$data->id), 200);
}
您可以使用$this
构造函数变量在当前函数或控制器中实现“使用Laravel Eloquent的最后插入ID”(不添加任何额外的列)。
public function store(Request $request){
$request->validate([
'title' => 'required|max:255',
'desc' => 'required|max:5000'
]);
$this->project = Project::create([
'name' => $request->title,
'description' => $request->desc,
]);
dd($this->project->id); //This is your current/latest project id
$request->session()->flash('project_added','Project added successfully.');
return redirect()->back();
}
public function store( UserStoreRequest $request ) {
$input = $request->all();
$user = User::create($input);
$userId=$user->id
}
使用口才模型
use App\Company;
public function saveDetailsCompany(Request $request)
{
$createcompany=Company::create(['nombre'=>$request->input('name'),'direccion'=>$request->input('address'),'telefono'=>$request->input('phone'),'email'=>$request->input('emaile'),'giro'=>$request->input('type')]);
// Last Inserted Row ID
echo $createcompany->id;
}
使用查询生成器
$createcompany=DB::table('company')->create(['nombre'=>$request->input('name'),'direccion'=>$request->input('address'),'telefono'=>$request->input('phone'),'email'=>$request->input('emaile'),'giro'=>$request->input('type')]);
echo $createcompany->id;
有关在Laravel中获取最后插入行ID的更多方法: http ://phpnotebook.com/95-laravel/127-3-methods-to-get-last-inserted-row-id-in-laravel
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.