控制器沒有添加對應的組件,因為比較簡單,而且在路由組件中也有對應的功能,所以只是實習了模塊化添加.
下面將添加模型組件,模型組件相當于MVC中的M,實習數據處理功能,這部分將使用laravel框架中的"illuminate/database"組件來完成
composer.json文件
~~~
{
"require": {
"illuminate/routing": "*",
"illuminate/events": "*",
"illuminate/database": "*"
},
"autoload": {
"psr-4": {
"App\\": "app/"
}
}
}
~~~
"illuminate/database"組件主要用于操作數據庫,它提供了兩種操作數據庫的方式,一種是查詢構造器方式,另一種是Eloquent ORM方式,這里使用Eloquent ORM方式,通過該方式操作數據庫非常簡單,
通過Eloquent ORM方式操作數據庫需要完成下面五個步驟,分別是創建數據庫,添加數據庫配置信息,啟動Eloquent ORM模塊,創建model類和通過model類操作數據庫
我們來創建一個表名字叫"students",添加3個字段,分別是'id','name','age'
laravel項目的目錄結構,在項目目錄下創建config文件夾,該文件夾用于存放其中整個應用程序的配置文件,在該文件夾下創建"database.php"文件,用于存儲對數據庫的配置信息.其中,配置文件都是以數組形式提供配置信息的
數據庫配置內容如下
config/database.php
~~~
<?php
return [
'driver' => 'mysql',
'host' => '127.0.0.1',
'database' => 'app',
'username' => 'root',
'password' => 'root',
'charset' => 'utf8',
'collation' => 'utf8_general_ci',
'prefix' => ''
];
~~~
在完成配置數據庫的主機地址,數據庫名稱用戶名和密碼等信息.需要啟動ORM模塊,這部分工作是訪問入口文件實現的
具體內容如下:
public/index.php
~~~
<?php
use Illuminate\Database\Capsule\Manager;
//調用自動加載文件,添加自動加載文件函數
require __DIR__.'/../vendor/autoload.php';
//實例化服務容器,注冊事件,路由服務提供者
$app = new Illuminate\Container\Container;
with(new Illuminate\Events\EventServiceProvider($app))->register();
with(new Illuminate\Routing\RoutingServiceProvider($app))->register();
//啟動ORM模塊并進行相關配置
$manager = new Manager();
$manager->addConnection(require '../config/database.php');
$manager->bootEloquent();
//加載路由
require __DIR__.'/../app/Http/routes.php';
//實例化請求分發處理請求
$request = Illuminate\Http\Request::createFromGlobals();
$response = $app['router']->dispatch($request);
//返回請求響應
$response->send();
~~~
啟動ORM模塊需要用到數據庫的的管理類,即`Illuminate\Database\Capsule\Manager`類,于是添加了對應的命名空間并進行初始化,然后通過addConnection()函數完成數據庫的相關配置并通過bootEloquent()函數完成數據庫ORM模塊的啟動.在啟動完成后,就可以操作數據庫了.通過ORM方式操作數據庫需要兩個步驟來實現,一是創建模型類,二是通過模型類的方法操作數據庫
laravel框架會將模型類直接放在app目錄下,這里會在app目錄下創建一個Models文件夾,用于統一管理,使得程序看起來更加模塊化,我們在Models文件夾下創建"Students.php",
app\Models\Student.php
~~~
<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Model;
class Student extends Model
{
public $timstamps = false;
}
~~~
控制器
~~~
<?php
namespace App\Http\Controllers;
use App\Models\Student;
class WeclomeController
{
public function index()
{
$student = Student::first();
$data = $student->getAttributes();
return $data;
}
}
~~~
- 書列表
- laravel框架關鍵技術
- 第一章 組件化開發與composer使用
- 簡介
- composer
- 添加路由組件
- 添加控制器模塊
- 添加模型組件
- 添加視圖組件
- 第三章 laravel框架中常用的php語法
- 匿名函數
- 文件包含
- 魔術方法
- 魔術常量
- 反射
- 后期靜態綁定
- traits
- 第四章 laravel框架中使用的HTTP協議基礎
- HTTP協議
- 數據庫
- 數據遷移
- 第六章 laravel框架中的設計模式
- IOC模式
- php核心技術與最佳實踐
- 第一章面向對象核心
- 反射
- 簡單ORM
- 異常和錯誤
- 接口
- 第二章,面向對象設計
- 設計原則
- 單一職責
- 接口隔離
- 開放封閉
- 替換原則
- 依賴倒置
- linux是怎么寫的呢?
- 第三章 正則表達
- 認識正則
- 第四章 php網絡技術應用
- HTTP協議詳解
- php和http相關函數
- 垃圾信息防御措施
- 現代操作系統
- 引論
- sql必知必會
- 限制結果
- 按位置排序
- where求職順序
- IN操作符
- like
- 函數
- group by
- 組合查詢
- 插入檢索出的數據
- 視圖
- 高性能mysql
- 第一章節 mysql架構與歷史
- mysql架構邏輯圖
- 連接與管理
- 優化與運行
- 讀寫鎖
- 鎖粒度
- 表鎖(table lock)
- 行級鎖(row lock)
- ACID
- 隔離級別
- 死鎖
- 隱式和顯式鎖定
- 多版本并發控制
- Innodb概覽
- 第四章節 Schema與數據類型優化
- 選擇優化的數據類型
- 日期和時間類型
- 標識列
- 特殊類型數據
- 表設計中的缺陷
- 范式
- 計數器表
- 第五章 創建高性能索引
- 索引基礎
- 索引類型
- 索引的優點
- 高性能索引策略
- 選擇合適的索引列順序
- 聚簇索引
- 順序的主鍵什么時候會造成更壞的后果
- 覆蓋索引
- 使用索引掃描來做排序
- 壓縮索引
- 冗余和重復索引
- 索引和鎖
- 支持多種過濾條件
- 什么是范圍條件
- 優化排序
- 維護索引和表
- 表損壞
- 減少索引和數據的碎片
- 第六章 查詢性能優化
- 掃描的行數和訪問類型
- 重構查詢方式
- 查詢執行的基礎
- 重構-改善既有代碼設計
- 第一章-重構
- 什么是重構
- 第一個案列
- 重構第一步
- 王垠博客
- 多態取代價格相關邏輯