Hôm nay, chúng tôi chia sẻ với các bạn cách lấy ID được chèn lần cuối trong laravel với 4 ví dụ đơn giản. chúng tôi cần một số ID được chèn lần cuối trong ứng dụng laravel. Vì vậy, ở đây chúng tôi đã tìm thấy 4 cách khác nhau để lấy ID được chèn lần cuối trong laravel. bạn có thể sử dụng nó và lấy ID cuối cùng của bản ghi đã chèn trong ứng dụng laravel
1] Sử dụng phương thức insertGetId[]
Ví dụ, bạn có thể lấy ID được chèn lần cuối bằng cách sử dụng insertGetId[] trong laravel
$id = DB::table['users']->insertGetId[
[ 'name' => 'first' ]
];
dd[$id];
[THÊM MÃ]
2] Sử dụng phương thức lastInsertId[]
Bạn cũng có thể lấy ID được chèn lần cuối bằng cách sử dụng lastInsertId[] trong laravel. Bạn cần đối tượng PDO để chạy phương thức này chẳng hạn
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
3] Sử dụng phương thức tạo []
Có, bạn cũng có thể lấy ID cuối cùng bằng cách sử dụng phương thức tạo [] của laravel với Mô hình laravel. phương thức này trả về đối tượng bản ghi được chèn lần cuối và bạn có thể sử dụng đối tượng này ID được chèn lần cuối. Ví dụ
$data = User::create[['name'=>'first']];
dd[$data->id];
4] Sử dụng phương thức save[]
Bạn cũng có thể lấy ID được chèn lần cuối bằng phương thức save[] của laravel. nếu bạn sử dụng phương thức save[] để chèn dữ liệu thì bạn có thể lấy id được chèn lần cuối như thế
$data = new User;
$data->name = 'Test';
$data->save[];
dd[$data->id];
Chúng tôi hy vọng hướng dẫn nhỏ này sẽ giúp mọi người. nếu bạn biết thêm cách để lấy ID được chèn lần cuối trong laravel, vui lòng nhận xét bên dưới. Thanks
Trong hướng dẫn này, Cách lấy bản ghi cuối cùng từ bảng bằng PHP Laravel, tôi sẽ chỉ cho chúng ta hai cách để lấy hàng cuối cùng đơn giản của bảng cơ sở dữ liệu. Trong ví dụ đơn giản này, tôi sẽ sử dụng phương thức 3 laravel sau đây, ví dụ ở đây chỉ cho bạn Cách lấy bản ghi cuối cùng của bảng trong Laravel 5
1]first[]
2]orderBy[]
3]latest[]
Ba điều đơn giản trên . và chúng ta có thể sử dụng phương thức mới nhất đơn giản để lấy bản ghi cuối cùng từ bảng cơ sở dữ liệu trong ứng dụng Laravel đơn giản.
Nhận bản ghi cuối cùng từ bảng bằng mệnh đề orderBy đơn giản
$get_last_row=DB::table['products']->orderBy['id', 'DESC']->first[];
Nhận bản ghi cuối cùng từ cơ sở dữ liệu bảng bằng phương pháp mới nhất
Tôi có bảng "mục" đơn giản sử dụng trong cơ sở dữ liệu và tôi chỉ muốn lấy bản ghi cuối cùng của "mục" trong bảng bản ghi. Trong ví dụ đơn giản đầu tiên, tôi sử dụng bản ghi mới nhất [] với bản ghi đầu tiên [] vì bản ghi mới nhất [] sẽ chỉ tìm nạp bản ghi mới nhất đơn giản theo have new created_at thì bản ghi first[] sẽ chỉ nhận được mỗi bản ghi duy nhất
$get_last_row = DB::table['products']->latest[]->first[];
Sử dụng mới nhất[] thuộc về trường created_at
$get_last_row = DB::table['items']->latest[]->first[];
Sử dụng orderBy[] thuộc trường id
$get_last_row2 = DB::table['items']->orderBy['id', 'DESC']->first[];
Sử dụng mới nhất[] thuộc trường id
________số 8Laravel truy vấn bản ghi mới nhất
public function users[] { return $this->belongsToMany[User::class, 'message']->orderBy['id', 'desc']; }
Nếu chúng tôi muốn giới hạn tổng số người dùng được trả lại đơn giản và phần bổ sung khác ->take[10];
Trình tạo truy vấn cơ sở dữ liệu cung cấp giao diện thuận tiện, thông thạo để tạo và chạy các truy vấn cơ sở dữ liệu. Nó có thể được sử dụng để thực hiện hầu hết các hoạt động cơ sở dữ liệu trong ứng dụng của bạn và hoạt động trên tất cả các hệ thống cơ sở dữ liệu được hỗ trợ
Ghi chú. Trình tạo truy vấn của Laravel sử dụng liên kết tham số PDO xuyên suốt để bảo vệ ứng dụng của bạn khỏi các cuộc tấn công SQL injection. Không cần xóa các chuỗi được truyền dưới dạng ràng buộc
chọn
Lấy tất cả các hàng từ một bảng
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
0Truy xuất một hàng từ một bảng
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
1Truy xuất một cột từ một hàng
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
2Truy xuất danh sách các giá trị cột
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
3Phương thức này sẽ trả về một mảng các chức danh vai trò. Bạn cũng có thể chỉ định cột khóa tùy chỉnh cho mảng được trả về
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
4Chỉ định một mệnh đề chọn
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
5Thêm một mệnh đề chọn vào một truy vấn hiện có
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
6Sử dụng toán tử Where
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
7Hoặc Tuyên bố
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
8Sử dụng ở đâu giữa
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
9Sử dụng Where Not Between
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
10Sử dụng Where In với một mảng
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
11Sử dụng Where Null để tìm bản ghi với giá trị chưa đặt
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
12Sắp xếp theo, theo nhóm và có
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
13Bù trừ & Giới hạn
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
14tham gia
Trình tạo truy vấn cũng có thể được sử dụng để viết các câu lệnh nối. Hãy xem các ví dụ sau
Tuyên bố tham gia cơ bản
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
15Tuyên bố tham gia trái
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
16Bạn cũng có thể chỉ định các mệnh đề nối nâng cao hơn
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
17Nếu bạn muốn sử dụng mệnh đề kiểu "where" trên các phép nối của mình, bạn có thể sử dụng các phương thức
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
39 và DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
40 trên một phép nối. Thay vì so sánh hai cột, các phương thức này sẽ so sánh cột với một giá trịDB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
18Nâng cao
Nhóm tham số
Đôi khi, bạn có thể cần tạo các mệnh đề where nâng cao hơn, chẳng hạn như "nơi tồn tại" hoặc các nhóm tham số lồng nhau. Trình tạo truy vấn của Laravel cũng có thể xử lý những điều này
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
19Truy vấn trên sẽ tạo ra SQL sau
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
20Tồn tại báo cáo
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
21Truy vấn trên sẽ tạo ra SQL sau
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
22uẩn
Trình tạo truy vấn cũng cung cấp nhiều phương thức tổng hợp, chẳng hạn như
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
41, DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
42, DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
43, DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
44 và DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
45Sử dụng các phương pháp tổng hợp
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
23biểu thức thô
Đôi khi bạn có thể cần sử dụng biểu thức thô trong truy vấn. Các biểu thức này sẽ được đưa vào truy vấn dưới dạng chuỗi, vì vậy hãy cẩn thận để không tạo bất kỳ điểm chèn SQL nào. Để tạo một biểu thức thô, bạn có thể sử dụng phương thức
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
46Sử dụng biểu thức thô
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
24phụ trang
Chèn bản ghi vào bảng
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
25Chèn bản ghi vào bảng có ID tăng tự động
Nếu bảng có id tăng tự động, hãy sử dụng
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
47 để chèn bản ghi và truy xuất idDB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
26Ghi chú. Khi sử dụng PostgreSQL, phương thức insertGetId yêu cầu cột tăng tự động được đặt tên là "id"
Chèn nhiều bản ghi vào một bảng
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
27cập nhật
Cập nhật các bản ghi trong một bảng
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
28Tăng hoặc giảm giá trị của một cột
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
29Bạn cũng có thể chỉ định các cột bổ sung để cập nhật
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
30xóa
Xóa các bản ghi trong một bảng
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
31Xóa tất cả các bản ghi khỏi một bảng
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
32Cắt bớt một bảng
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
33đoàn thể
Trình tạo truy vấn cũng cung cấp một cách nhanh chóng để "kết hợp" hai truy vấn với nhau
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
34Phương thức
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
48 cũng có sẵn và có cùng chữ ký phương thức như DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
49khóa bi quan
Trình tạo truy vấn bao gồm một vài hàm để giúp bạn thực hiện "khóa bi quan" trên các câu lệnh CHỌN của mình
Để chạy câu lệnh SELECT với "khóa chia sẻ", bạn có thể sử dụng phương thức
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
50 trên một truy vấnDB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
35Để "khóa để cập nhật" trên câu lệnh SELECT, bạn có thể sử dụng phương thức
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
51 trên một truy vấnDB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
36Truy vấn bộ đệm
Bạn có thể dễ dàng lưu trữ kết quả truy vấn bằng cách sử dụng phương pháp
DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
52 hoặc DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
53DB::table['users']->insert[[
'name' => 'TestName'
]];
$id = DB::getPdo[]->lastInsertId[];;
dd[$id];
37Trong ví dụ này, kết quả của truy vấn sẽ được lưu vào bộ đệm trong mười phút. Trong khi kết quả được lưu vào bộ nhớ cache, truy vấn sẽ không được chạy đối với cơ sở dữ liệu và kết quả sẽ được tải từ trình điều khiển bộ đệm mặc định được chỉ định cho ứng dụng của bạn