1. Trang chủ
  2. » Công Nghệ Thông Tin

Bài giảng Phát triển phần mềm nguồn mở (GV Nguyễn Hữu Thể) Bài 11

57 45 0

Đang tải... (xem toàn văn)

Tài liệu hạn chế xem trước, để xem đầy đủ mời bạn chọn Tải xuống

THÔNG TIN TÀI LIỆU

Thông tin cơ bản

Tiêu đề Database, Migrations & Seeding
Tác giả Nguyễn Hữu Thể
Định dạng
Số trang 57
Dung lượng 1 MB

Nội dung

PHÁT TRIỂN PHẦN MỀM NGUỒN MỞ DATABASE, MIGRATIONS & SEEDING Nguyễn Hữu Thể Database ❖ Introduction ❖ Configuration ❖ Read & Write Connections Giới thiệu − Laravel kết nối tới database thực thi query với nhiều database back-ends thơng qua sử dụng • raw SQL, • fluent query builder, • Eloquent ORM − Hiện tại, Laravel hỗ trợ sẵn database: • • • • MySQL Postgres SQLite SQL Server Cấu hình − Thư mục config/database.php • Trong file này: định nghĩa tất kết nối sở liệu, định connection mặc định ❖ Cấu hình SQL Server 'sqlsrv' => [ 'driver' => 'sqlsrv', 'host' => env('DB_HOST', 'localhost'), 'database' => env('DB_DATABASE', 'forge'), 'username' => env('DB_USERNAME', 'forge'), 'password' => env('DB_PASSWORD', ''), 'charset' => 'utf8', 'prefix' => '', ], Đọc & ghi kết nối 'mysql' => [ 'read' => [ 'host' => '192.168.1.1', ], 'write' => [ 'host' => '196.168.1.2' ], 'driver' => 'mysql', 'database' => 'database', 'username' => 'root', 'password' => '', 'charset' => 'utf8', 'collation' => 'utf8_unicode_ci', 'prefix' => '', ], Thiết lập database file cấu hình chung env (Tên_Project/.env) APP_ENV=local APP_KEY=base64:SPqqJfE1ADzonR ot2o5g9J8Ix3iRVHsFOclr0KC1KHI= APP_DEBUG=true APP_LOG_LEVEL=debug APP_URL=http://localhost DB_CONNECTION=mysql DB_HOST=127.0.0.1 DB_PORT=3306 DB_DATABASE=ten_database DB_USERNAME=root DB_PASSWORD= BROADCAST_DRIVER=log CACHE_DRIVER=file SESSION_DRIVER=file QUEUE_DRIVER=sync REDIS_HOST=127.0.0.1 REDIS_PASSWORD=null REDIS_PORT=6379 MAIL_DRIVER=smtp MAIL_HOST=mailtrap.io MAIL_PORT=2525 MAIL_USERNAME=null MAIL_PASSWORD=null MAIL_ENCRYPTION=null PUSHER_APP_ID= PUSHER_KEY= PUSHER_SECRET= Thực thi lệnh select namespace App\Http\Controllers; use Illuminate\Support\Facades\DB; use App\Http\Controllers\Controller; class UserController extends Controller { public function index() { $users = DB::select('select * from users where active = ?', [1]); return view('user.index', ['users' => $users]); } } Có thể thực thi câu query sử dụng liên kết đặt tên: $results = DB::select('select * from users where id = :id', ['id' => 1]); Thực thi lệnh select Syntax array select(string $query, array $bindings = array()) Parameters •$query(string) – query to execute in database •$bindings(array) – values to bind with queries Returns array Description Run a select statement against the database Thực thi câu lệnh insert − Hàm insert nhận câu raw SQL query tham số đầu tiên, bindings tham số thứ hai DB::insert('insert into users (id, name) values (?, ?)', [1, ‘Tom']); Syntax bool insert(string $query, array $bindings = array()) Parameters •$query(string) – query to execute in database •$bindings(array) – values to bind with queries Returns bool Description Run an insert statement against the database Thực thi câu lệnh update − Hàm update: update records có sở liệu Số lượng row ảnh hưởng câu lệnh trả qua hàm $affected = DB::update('update users set votes = 100 where name = ?', ['John']); Syntax int update(string $query, array $bindings = array()) Parameters •$query(string) – query to execute in database •$bindings(array) – values to bind with queries Returns int Description Run an update statement against the database 10 Cấu trúc migration use Illuminate\Support\Facades\Schema; use Illuminate\Database\Schema\Blueprint; use Illuminate\Database\Migrations\Migration; class CreateFlightsTable extends Migration { public function up() //đoạn lệnh thực migrate { Schema::create('flights', function (Blueprint $table) { $table->increments('id'); $table->string('name'); $table->string('airline'); $table->timestamps(); }); } public function down() //đoạn lệnh thực Rollback { Schema::drop('flights'); } } 43 Thực thi Migrations − Để thực thi tất migration chương trình, sử dụng lệnh: php artisan migrate 44 Rolling Back Migrations - Hủy bỏ việc thực thi migrate trước php artisan migrate:rollback − Lệnh migrate:reset thực rollback lại tồn migration chương trình php artisan migrate:reset − Rollback & Migrate câu lệnh • Lệnh migrate:refresh rollback lại tồn migration chương trình, thực câu lệnh migrate Câu lệnh thực tái cấu trúc toàn database: php artisan migrate:refresh 45 Ví dụ demo: tạo tên database laravelk (trống, chưa có table) − Vào thư mục project: Nhấn Ctrl+Shift+ Chuột phải > Open Command Promt Here − Gõ vào CMD: C:\xampp\htdocs\laravelk>php artisan migrate Migration table created successfully Migrated: 2014_10_12_000000_create_users_table Migrated: 2014_10_12_100000_create_password_resets_table − Xuất table: 46 Bảng lưu lại trình tạo bảng − batch = 1: tạo lần đầu 47 Tạo migration table_SanPham C:\xampp\htdocs\laravelk>php artisan make:migration table_SanPham Created Migration: 2016_12_19_130901_table_SanPham 48 Kiểm tra: database\migrations\2016_12_19_130901_table_SanPham.php use Illuminate\Support\Facades\Schema; use Illuminate\Database\Schema\Blueprint; use Illuminate\Database\Migrations\Migration; class TableSanPham extends Migration{ //Viết code cho migration public function up() { Schema::create('sanpham', function($table){ $table->increments('id'); $table->string('ten'); $table->integer('soluong'); }); } public function down() { Schema::drop('sanpham'); } } 49 Run Migrate C:\xampp\htdocs\laravelk>php artisan migrate Migrated: 2016_12_19_130901_table_SanPham Kiểm tra table Kiểm tra migrate 50 Hủy migrate, quay lại phiên trước php artisan migrate:rollback C:\xampp\htdocs\laravelk>php artisan migrate:rollback Rolled back: 2016_12_19_130901_table_SanPham Kiểm tra: xóa table_SanPham 51 Hủy bỏ hết cơng việc migrate php artisan migrate:reset C:\xampp\htdocs\laravelk>php artisan migrate:reset Rolled back: 2014_10_12_100000_create_password_resets_table Rolled back: 2014_10_12_000000_create_users_table Kiểm tra: tất table migration tạo 52 Seeding ❖ Introduction ❖ Writing Seeders ❖ Running Seeders 53 Seeding − Laravel có phương thức đơn giản để seed database với liệu test sử dụng seed class − Tất seed class lưu thư mục database/seeds − Viết Seeders • Để sinh seeder, gọi lệnh make:seeder Artisan Tất seeder sinh framework đặt thư mục database/seeds: php artisan make:seeder UsersTableSeeder 54 Seeding use Illuminate\Database\Seeder; use Illuminate\Database\Eloquent\Model; class DatabaseSeeder extends Seeder { public function run() //Viết code tạo table users { DB::table('users')->insert([ 'name' => str_random(10), 'email' => str_random(10).'@gmail.com', 'password' => bcrypt('secret'), ]); } } 55 Thực thi Seeders − Khi có seeder class • Có thể sử dụng câu lệnh db:seed Artisan để seed vào database • Mặc định, câu lệnh db:seed thực thi class DatabaseSeeder, mà bạn sử dụng để gọi seed class khác • Tuy nhiên, bạn sử dụng tuỳ chọn class để định thực seed class php artisan db:seed php artisan db:seed class=UsersTableSeeder 56 Ví dụ: tạo table users use Illuminate\Database\Seeder; class DatabaseSeeder extends Seeder { public function run() { DB::table ( 'users' )->insert ( [ 'name' => 'Tom', 'email' => 'tom@gmail.com', 'password' => bcrypt('123456') ] ); } } Mở cửa sổ cmd : php artisan db:seed Kiểm tra liệu: 57 ... values to bind with queries Returns int Description Run a delete statement against the database 11 Thực thi câu lệnh chung − Một vài câu lệnh sở liệu không trả giá trị Với thao tác kiểu này, sử... DB::statement('drop table users'); 12 Database Example − Table student Column Name Column Datatype Id int (11) Name varchar(25) Extra Primary key | Auto increment − We will see how to add, delete, update... 8, 2); $table->increments('id'); $table->integer('votes'); Tương đương với DECIMAL với độ sách phần thập phân Tương đương với DOUBLE với độ xác, 15 chữ số ký tự tính sau dấu phảy Tương đương

Ngày đăng: 30/10/2021, 11:09

HÌNH ẢNH LIÊN QUAN

Cấu hình - Bài giảng Phát triển phần mềm nguồn mở (GV Nguyễn Hữu Thể) Bài 11
u hình (Trang 4)
Thiết lập database trong file cấu hình chung .env (Tên_Project/.env) APP_ENV=local APP_KEY=base64:SPqqJfE1ADzonR ot2o5g9J8Ix3iRVHsFOclr0KC1KHI= APP_DEBUG=true APP_LOG_LEVEL=debug APP_URL=http://localhost DB_CONNECTION=mysql DB_HOST=127.0.0.1 DB_PORT=3306 - Bài giảng Phát triển phần mềm nguồn mở (GV Nguyễn Hữu Thể) Bài 11
hi ết lập database trong file cấu hình chung .env (Tên_Project/.env) APP_ENV=local APP_KEY=base64:SPqqJfE1ADzonR ot2o5g9J8Ix3iRVHsFOclr0KC1KHI= APP_DEBUG=true APP_LOG_LEVEL=debug APP_URL=http://localhost DB_CONNECTION=mysql DB_HOST=127.0.0.1 DB_PORT=3306 (Trang 6)
->first () Đặt column "first" vào trong bảng (MySQL - Bài giảng Phát triển phần mềm nguồn mở (GV Nguyễn Hữu Thể) Bài 11
gt ;first () Đặt column "first" vào trong bảng (MySQL (Trang 34)
echo "Đã tạo bảng loaisanpham" ; }); - Bài giảng Phát triển phần mềm nguồn mở (GV Nguyễn Hữu Thể) Bài 11
echo "Đã tạo bảng loaisanpham" ; }); (Trang 35)
echo "Đã tạo bảng" ; - Bài giảng Phát triển phần mềm nguồn mở (GV Nguyễn Hữu Thể) Bài 11
echo "Đã tạo bảng" ; (Trang 36)
echo "Đã tạo bảng liên kết" ; } ); - Bài giảng Phát triển phần mềm nguồn mở (GV Nguyễn Hữu Thể) Bài 11
echo "Đã tạo bảng liên kết" ; } ); (Trang 37)
$table-> dropColumn('TenCot'); Xóa cột trong bảng - Bài giảng Phát triển phần mềm nguồn mở (GV Nguyễn Hữu Thể) Bài 11
table > dropColumn('TenCot'); Xóa cột trong bảng (Trang 38)
Bảng lưu lại quá trình tạo bảng - Bài giảng Phát triển phần mềm nguồn mở (GV Nguyễn Hữu Thể) Bài 11
Bảng l ưu lại quá trình tạo bảng (Trang 47)

TÀI LIỆU CÙNG NGƯỜI DÙNG

TÀI LIỆU LIÊN QUAN

w