[TOC]
`php artisan make:model User`
會發現Model already exists! 在app\User.php發現里面之前有個User.php這是他的一個示例文件,把這文件刪除 刪除之后再創建,然后建個Model文件夾,把創建好的user.php移動到這里,改下命名空間
默認表是表示模型的復數
# 表名和Model類名的關系
## 默認表名
默認情況下,系統會猜測類名的復數為表名,比如:
* 類名 ->表名
* User ->users類名的復數,便是表名
* UserAvatarAttachment ->user_avatar_attachments
多個單詞,類名每個單詞的首字母大寫,表名會自動加上下劃線,并在結尾加上復數
* Media ->mediamedia 沒有復數
* Factory ->factories識別元音,轉換-ies
* Woman ->women特殊單詞的復數也可以正常識別,還有man、leaf等
Laravel 中有一套完善的單詞復數轉換程序,在大部分情況下,都能得到單詞的正確復數 無意義的單詞,會按照常規,在末字母加上-s、-es或-ies
## 指定表名
protected $table \= 'customer';
# 字段白名單、黑名單
## 字段黑名單(寫入)
如果你不希望數據庫中插入id(因為id是自增量)
`protected $guarded = ['id'];`
這樣,creat、update、save等方法都會過濾這個字段的寫入
~~~
User::create([
'id' => 25, //會自動過濾這項
'username' => 'dick',
])
~~~
>Model默認配置$guarded = ['*']表示拒絕所有字段的寫入
## 關閉黑名單
Model默認啟用黑名單
~~~
protected static $unguarded = true; //關閉
或
User::$unguarded = true;
~~~
## 字段白名單(寫入)
`protected $fillable = ['username', 'password'];`
白名單一般配合$`guarded = ['*']`來使用。在全黑名單的情況下,設置某些字段為白名單
# 數據隱藏或顯示
數據隱藏(讀取時)
如果希望在輸出數據時,不顯示password、token等字段
`protected $hidden = ['password','token'];`
這樣在`toArray()、toJson()`時,會自動去除這些數據
注意:`$user->password、$user['password']` 可正常使用,僅僅在`toArray()、toJson()`時過濾這些數據
數據顯示
當`$hidden = ['*']`時,可啟用
`protected $visible = ['username','gender'];`
# 附加字段/數據
Model 可以自創一些字段來增加程序的可用性。 注意:這些字段是不會插入數據庫的
~~~
class Role extends Model {
protected $appends = ['is_admin'];
public function getIsAdminAttribute()
{
return $this->getKey() == 99;
}
}
$role = Role::find(99);
echo $role->is_admin; //true
$appends 也可以結合 $hidden/$visible 用
~~~
# 數據庫連接
不要忘記在配置文件中.env更改連接數據庫的一些值 測試連接數據庫,注意要在DB前面加\
~~~
$pdo=\DB::connection()->getPdo(); dd($pdo);
$rel = DB::connection('mysql_read')->where(...)->update(...);
~~~
也可以在模型中指定數據庫連接:
`public $connection = 'mysql_read';`
## 指定查詢時連接數據庫
您也可以指定在執行 Eloquent 查詢時要使用哪個數據庫連接。只要使用`on`方法:
~~~
$user = User::on('connection-name')->find(1);
~~~
如果您在使用`讀取 / 寫入`連接, 您可以通過如下命令來強制查詢使用`寫入`連接:
~~~
$user = User::onWriteConnection()->find(1);
~~~
# 中間表類型轉換
Laravel 5.5 新增了向中間表模型插入或者更新數據時對類型轉換的支持。
目前,在原來的模型中你可以用`$casts`來雙向轉換。任何繼承`Eloquent\Model`類的模型都會查找`$casts`屬性,并在讀取和寫入時將指定的屬性轉化為數據類型
~~~
protected $casts = [
'email_verified_at' => 'datetime',
];
~~~
在 Laravel 5.4 中,Taylor 也在自定義中間表模型上添加了定義`$casts`屬性的功能,但是只在讀取數據時應用了`$casts`,而插入或更新屬性時并不會執行轉換
- 配置
- composer安裝
- composer用法
- composer版本約束表達
- phpstorm
- sftp文件同步
- php類型約束
- laradock
- 配置文件緩存詳解
- git
- 自定義函數
- 核心概念
- IOC
- 服務提供者
- Facade
- 契約
- 生命周期
- 路由
- 請求
- 命名路由
- 路由分組
- 資源路由
- 控制器路由
- 響應宏
- 響應
- Command
- 創建命令
- 定時任務
- console路由
- 執行用戶自定義的定時任務
- artisan命令
- 中間件
- 創建中間件
- 使用中間件
- 前置和后置
- 詳細介紹
- 訪問次數限制
- 為 VerifyCsrfToken 添加過濾條件
- 單點登錄
- 事件
- 創建
- ORM
- 簡介
- DB類
- 配置
- CURD
- queryScope和setAttribute
- 查看sql執行過程
- 關聯關系
- 一對一
- 一對多
- 多對多
- 遠程關聯
- 多態一對多
- 多態多對多
- 關聯數據庫的調用
- withDefault
- 跨模型更新時間戳
- withCount,withSum ,withAvg, withMax,withMin
- SQL常見操作
- 模型事件
- 模型事件詳解
- 模型事件與 Observer
- deleted 事件未被觸發
- model validation
- ORM/代碼片段
- Repository模式
- 多重where語句
- 中間表類型轉換
- Collection集合
- 新增的一些方法
- 常見用法
- 求和例子
- 機場登機例子
- 計算github活躍度
- 轉化評論格式
- 計算營業額
- 創建lookup數組
- 重新組織出表和字段關系并且字段排序
- 重構循環
- 其他例子
- 其他問題一
- 去重
- 第二個數組按第一個數組的鍵值排序
- 搜索ES
- 安裝
- 表單
- Request
- sessiom
- Response
- Input
- 表單驗證
- 簡介
- Validator
- Request類
- 接口中的表單驗證
- Lumen 中自定義表單驗證返回消息
- redis
- 廣播事件
- 發布訂閱
- 隊列
- 守護進程
- redis隊列的坑
- beanstalkd
- rabbitmq
- redis隊列
- 日志模塊
- 錯誤
- 日志詳解
- 數據填充與遷移
- 生成數據
- 數據填充seed
- migrate
- 常見錯誤
- Blade模板
- 流程控制
- 子視圖
- URL
- 代碼片段
- Carbon時間類
- 一些用法
- 郵件
- 分頁
- 加密解密
- 緩存
- 文件上傳
- 優化
- 隨記
- 嵌套評論
- 判斷字符串是否是合法的 json 字符串
- 單元測試
- 計算出兩個日期的diff
- 自定義一個類文件讓composer加載
- 時間加減
- 對象數組互轉方法
- 用戶停留過久自動退出登錄
- optional 輔助方法
- 文件下載
- Api
- Dingo api
- auth.basic
- api_token
- Jwt-Auth
- passport
- Auth
- Authentication 和 Authorization
- Auth Facade
- 授權策略
- Gates
- composer包
- debug包
- idehelp包
- image處理
- 驗證碼
- jq插件
- 第三方登錄
- 第三方支付
- log顯示包
- 微信包
- xss過濾
- Excel包
- MongoDB
- php操作
- 聚合查詢
- 發送帶附件郵件
- 中文轉拼音包
- clockwork網頁調試
- emoji表情
- symfony組件
- swooletw/laravel-swoole
- 常見問題
- 跨域問題
- Laravel隊列優先級的一個坑
- cache:clear清除緩存問題
- .env無法讀取
- 源碼相關基礎知識
- __set和__get
- 依賴注入、控制反轉和依賴倒置原則
- 控制反轉容器(Ioc Container)
- 深入服務容器
- call_user_func
- compact
- 中間件簡易實現
- array_reduce
- 中間件實現代碼
- Pipeline管道操作
- composer自動加載
- redis延時隊列
- 了解laravel redis隊列
- cli
- 源碼解讀
- Facade分析
- Facade源碼分析
- IOC服務容器
- 中間件原理
- 依賴注入淺析
- 微信
- 微信公眾號
- 常用接收消息
- 6大接收接口
- 常用被動回復消息
- 接口調用憑證
- 自定義菜單
- 新增素材
- 客服消息
- 二維碼
- 微信語音
- LBS定位
- 網頁授權
- JSSDK
- easywechat
- 小程序
- 小程序配置app.json