Laravel框架學(xué)習(xí)筆記(二)項(xiàng)目實(shí)戰(zhàn)之模型(Models)
在開(kāi)發(fā)mvc項(xiàng)目時(shí),models都是第一步。
下面就從建模開(kāi)始。
1.實(shí)體關(guān)系圖,
由于不知道php有什么好的建模工具,這里我用的vs ado.net實(shí)體模型數(shù)據(jù)建模
下面開(kāi)始laravel編碼,編碼之前首先得配置數(shù)據(jù)庫(kù)連接,在app/config/database.php文件
'mysql' => array( 'driver' => 'mysql', 'read' => array( 'host' => '127.0.0.1:3306', ), 'write' => array( 'host' => '127.0.0.1:3306' ), 'database' => 'test', 'username' => 'root', 'password' => 'root', 'charset' => 'utf8', 'collation' => 'utf8_unicode_ci', 'prefix' => '', ),
配置好之后,需要用到artisan工具,這是一個(gè)php命令工具在laravel目錄中
首先需要要通過(guò)artisan建立一個(gè)遷移 migrate ,這點(diǎn)和asp.net mvc幾乎是一模一樣
在laravel目錄中 shfit+右鍵打開(kāi)命令窗口 輸入artisan migrate:make create_XXXX會(huì)在app/database/migrations文件下生成一個(gè)帶時(shí)間戳前綴的遷移文件
代碼:
<?php use Illuminate\Database\Schema\Blueprint; use Illuminate\Database\Migrations\Migration; class CreateTablenameTable extends Migration { /** * Run the migrations. * * @return void */ public function up() { } /** * Reverse the migrations. * * @return void */ public function down() { } }
看到這里有entityframework 遷移經(jīng)驗(yàn)的基本上發(fā)現(xiàn)這是出奇的相似啊。
接下來(lái)就是創(chuàng)建我們的實(shí)體結(jié)構(gòu),laravel 的結(jié)構(gòu)生成器可以參考http://v4.golaravel.com/docs/4.1/schema
<?php use Illuminate\Database\Schema\Blueprint; use Illuminate\Database\Migrations\Migration; class CreateTablenameTable extends Migration { /** * Run the migrations. * * @return void */ public function up() { Schema::create('posts', function(Blueprint $table) { $table->increments('id'); $table->unsignedInteger('user_id'); $table->string('title'); $table->string('read_more'); $table->text('content'); $table->unsignedInteger('comment_count'); $table->timestamps(); }); Schema::create('comments', function(Blueprint $table) { $table->increments('id'); $table->unsignedInteger('post_id'); $table->string('commenter'); $table->string('email'); $table->text('comment'); $table->boolean('approved'); $table->timestamps(); }); Schema::table('users', function (Blueprint $table) { $table->create(); $table->increments('id'); $table->string('username'); $table->string('password'); $table->string('email'); $table->string('remember_token', 100)->nullable(); $table->timestamps(); }); } /** * Reverse the migrations. * * @return void */ public function down() { Schema::drop('posts'); Schema::drop('comments'); Schema::drop('users'); } }
繼續(xù)在上面的命令窗口輸入php artisan migrate 將執(zhí)行遷移
更多遷移相關(guān)知識(shí):http://v4.golaravel.com/docs/4.1/migrations
先寫(xiě)到這里明天繼續(xù)
- Laravel框架源碼解析之入口文件原理分析
- Laravel框架源碼解析之反射的使用詳解
- Laravel源碼解析之路由的使用和示例詳解
- 通過(guò)源碼解析Laravel的依賴(lài)注入
- laravel model模型定義實(shí)現(xiàn)開(kāi)啟自動(dòng)管理時(shí)間created_at,updated_at
- laravel model模型處理之修改查詢(xún)或修改字段時(shí)的類(lèi)型格式案例
- Laravel5.1 框架模型工廠ModelFactory用法實(shí)例分析
- Laravel 5框架學(xué)習(xí)之模型、控制器、視圖基礎(chǔ)流程
- Laravel模型事件的實(shí)現(xiàn)原理詳解
- Laravel模型間關(guān)系設(shè)置分表的方法示例
- laravel學(xué)習(xí)教程之關(guān)聯(lián)模型
- Laravel框架源碼解析之模型Model原理與用法解析
相關(guān)文章
ThinkPHP查詢(xún)語(yǔ)句與關(guān)聯(lián)查詢(xún)用法實(shí)例
這篇文章主要介紹了ThinkPHP查詢(xún)語(yǔ)句與關(guān)聯(lián)查詢(xún)用法,以實(shí)例的形式常見(jiàn)的查詢(xún)方法,包括數(shù)組作為查詢(xún)條件及對(duì)象方式來(lái)查詢(xún)等技巧,需要的朋友可以參考下2014-11-11Zend Framework實(shí)現(xiàn)多服務(wù)器共享SESSION數(shù)據(jù)的方法
這篇文章主要介紹了Zend Framework實(shí)現(xiàn)多服務(wù)器共享SESSION數(shù)據(jù)的方法,詳細(xì)分析了SESSION數(shù)據(jù)共享的原理與實(shí)現(xiàn)技巧,需要的朋友可以參考下2016-03-03yii2中使用webuploader實(shí)現(xiàn)圖片上傳的實(shí)戰(zhàn)項(xiàng)目
本篇文章主要主要介紹了yii2中使用webuploader實(shí)現(xiàn)圖片上傳的實(shí)戰(zhàn)項(xiàng)目,具有一定的參考價(jià)值,有興趣的同學(xué)可以了解一下2017-09-09thinkphp3.2實(shí)現(xiàn)上傳圖片的控制器方法
這篇文章主要介紹了thinkphp3.2實(shí)現(xiàn)上傳圖片的控制器方法,結(jié)合實(shí)例形式分析了thinkPHP圖片文件上傳相關(guān)的文件類(lèi)型判斷,文件路徑及相關(guān)屬性操作技巧,需要的朋友可以參考下2016-04-04php 購(gòu)物車(chē)完整實(shí)現(xiàn)代碼
本文介紹一個(gè)php實(shí)現(xiàn)的購(gòu)物車(chē)代碼,功能實(shí)現(xiàn)比較完整,實(shí)現(xiàn)了購(gòu)物車(chē)、訂貨人信息、會(huì)員價(jià)等功能,還是不錯(cuò)的,有需要的朋友,可以參考下2014-06-06codeigniter中view通過(guò)循環(huán)顯示數(shù)組數(shù)據(jù)的方法
這篇文章主要介紹了codeigniter中view通過(guò)循環(huán)顯示數(shù)組數(shù)據(jù)的方法,實(shí)例分析了codeigniter中view方法與數(shù)組遍歷的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-03-03