Laravel 的 查詢產生器 提供了一個強大、流暢的介面,用於在 PHP 中建立 SQL 查詢。它允許您以富有表現力的、類似 SQL 的語法與資料庫交互,同時抽像出大部分複雜性。
我們將演練 Laravel 應用程式中的典型用例,使用查詢產生器執行各種任務,例如選擇、插入、更新和刪除資料。
如果您沒有 Laravel 項目,您可以如下設定一個:
composer create-project --prefer-dist laravel/laravel laravel-query-builder cd laravel-query-builder php artisan serve
確保在 .env 檔案中設定資料庫配置:
DB_CONNECTION=mysql DB_HOST=127.0.0.1 DB_PORT=3306 DB_DATABASE=your_database DB_USERNAME=your_username DB_PASSWORD=your_password
運行遷移以建立預設表:
php artisan migrate
讓我們建立一個控制器來示範查詢產生器的用法:
php artisan make:controller UserController
使用以下程式碼編輯 UserController.php:
<?php namespace App\Http\Controllers; use Illuminate\Support\Facades\DB; use Illuminate\Http\Request; class UserController extends Controller { // Fetching all users from the users table public function index() { // Step 3: Select all users $users = DB::table('users')->get(); return response()->json($users); } // Insert a new user public function store(Request $request) { // Step 4: Insert a new user DB::table('users')->insert([ 'name' => $request->name, 'email' => $request->email, 'password' => bcrypt($request->password), ]); return response()->json(['message' => 'User created successfully!']); } // Update an existing user public function update(Request $request, $id) { // Step 5: Update user by ID DB::table('users') ->where('id', $id) ->update([ 'name' => $request->name, 'email' => $request->email, ]); return response()->json(['message' => 'User updated successfully!']); } // Delete a user public function destroy($id) { // Step 6: Delete user by ID DB::table('users')->where('id', $id)->delete(); return response()->json(['message' => 'User deleted successfully!']); } }
使用查詢產生器從使用者表中選取所有行:
$users = DB::table('users')->get();
回應範例:
[ { "id": 1, "name": "John Doe", "email": "john@example.com" }, { "id": 2, "name": "Jane Doe", "email": "jane@example.com" } ]
使用查詢產生器插入新使用者:
DB::table('users')->insert([ 'name' => 'Alice', 'email' => 'alice@example.com', 'password' => bcrypt('password123'), ]);
這會將新使用者加入到使用者表中。
要更新現有記錄,請使用 update():
DB::table('users') ->where('id', 1) ->update([ 'name' => 'John Smith', 'email' => 'johnsmith@example.com' ]);
這會更新使用者表中 ID 為 1 的使用者。
要從資料庫中刪除記錄,請使用delete():
DB::table('users')->where('id', 2)->delete();
這將刪除 ID 為 2 的使用者。
您可以連結其他方法來過濾資料或新增條件到查詢。
$users = DB::table('users') ->where('email', 'like', '%example.com%') ->orderBy('name', 'asc') ->get();
Laravel 的查詢產生器可以輕鬆對結果進行分頁。
$users = DB::table('users')->paginate(10);
使用資料庫事務來確保多個查詢執行成功。如果一個查詢失敗,所有變更都會回滾。
DB::transaction(function () { DB::table('users')->insert([ 'name' => 'John Doe', 'email' => 'john@example.com', 'password' => bcrypt('password123') ]); DB::table('orders')->insert([ 'user_id' => 1, 'order_total' => 500 ]); });
如果您需要執行原始 SQL,Laravel 的查詢產生器允許這樣做:
$users = DB::select('SELECT * FROM users WHERE id = ?', [1]);
Laravel 的查詢產生器提供了一種強大而靈活的方式與資料庫交互,抽象化了大部分 SQL 複雜性。透過分解每個部分——檢索、插入、更新、刪除、過濾等等——您可以以乾淨、有組織的方式輕鬆管理資料庫互動。
此範例提供了查詢產生器的基本指南。隨著應用程式的成長,您可以使用更多進階功能,例如連接、子查詢和 Eloquent 的預先載入。
以上是Laravel 入門:查詢產生器初學者指南的詳細內容。更多資訊請關注PHP中文網其他相關文章!