[转]Laravel 4之Eloquent ORM
定义Eloquent模型
模型通常放在app/models目录中,但是您可以自由地把它们放在任何地方,只要它能根据您的composer.json文件自动加载。除非显示地指定表名,Eloquent默认情况下将模型类名的小写,复数形式作为表名。如我们定义的模型为Game,那么它将操作games数据表。
<?php// app/models/Game.phpclassGameextendsEloquent{//}
然后就可以使用该模型
Route::get('/',function(){$game =newGame;$game->name ='Assassins Creed';$game->description ='Assassins VS templars.';$game->save();});
这是会提示错误,因为模型默认每个表创建时都有$table->timestamps();,所以你需要为表添加这两个字段或是在模型中关闭
public $timestamps =false;
你可以为模型指定数据表
public $table ='gamezilla_roar';
Eloquent 将假设每张表有一个名为 id 的主键。您可以定义 primaryKey 属性来覆盖这个约定。同样,您可以定义一个 connection 属性来覆盖在使用这个模型时所用的数据库连接。
读取模型数据
获取所有所有记录
$games =Game::all();
根据主键获取一条记录
$games =Game::fine(1);
[查询构建器] 中适用的函数在 Eloquent 模型的查询中同样适用。具体参考官方API手册
根据主键获取一条记录或者抛出一个异常
$model =User::findOrFail(1);$model =User::where('votes','>',100)->firstOrFail();
注册错误处理器,请监听 ModelNotFoundException
useIlluminate\Database\Eloquent\ModelNotFoundException;App::error(function(ModelNotFoundException $e){returnResponse::make('Not Found',404);});
指定查询的数据库连接
$user =User::on('connection-name')->find(1);
插入
$user =newUser;$user->name ='John';$user->save();
通常您的 Eloquent 模型将有自动递增的键。然而,如果您希望指定您自定义的键,在模型中设置 incrementing 属性为 false。
您也可以使用 create 函数在一行代码中保存一个新的模型。被插入的模型实例将从函数中返回。但是,在您这样做之前,您需要在模型中指定 fillable 或者 guarded 属性,因为所有 Eloquent 模型默认阻止集体赋值。
$user =User::create(array('name'=>'John'));
更新
$user =User::find(1);$user->email ='john@foo.com';$user->save();
有时您可能希望不仅保存模型,还有它的所有关系。为此,您可以使用 push 函数:
$user->push();
在一组模型上运行更新:
$affectedRows =User::where('votes','>',100)->update(array('status'=>2));
删除
$user =User::find(1);$user->delete();
根据主键删除一个模型
User::destroy(1);User::destroy(1,2,3);
一组模型中运行删除查询
$affectedRows =User::where('votes','>',100)->delete();
如果您希望简单的在一个模型中更新时间戳,可以使用 touch 函数
$user->touch();
软删除
并没有真的从数据库中删除。相反,一个 deleted_at 时间戳在记录中被设置。为一个模型开启软删除,在模型中指定 softDelete 属性
classUserextendsEloquent{protected $softDelete =true;}
在您的表中添加一个 deleted_at 字段,您可以在迁移中使用 softDeletes 函数:
$table->softDeletes();
当您在一个模型中调用 delete 函数,deleted_at字段将被设置为当前的时间戳。在使用软删除的模型中查询,被软删除的模型将不被包含进查询结果中。为了强制已删除的模型出现在结果集中,在查询中使用 withTrashed 函数:
$users =User::withTrashed()->where('account_id',1)->get();
希望在结果集中只包含软删除的模型,您可以使用 onlyTrashed 函数
$users =User::onlyTrashed()->where('account_id',1)->get();
恢复一个已被软删除的记录,使用 restore 函数:
$user->restore();
在查询中使用 restore 函数:
User::withTrashed()->where('account_id',1)->restore();
restore 函数也可以在关系中被使用:
$user->posts()->restore();
从数据库中真正删除一个模型,您可以使用 forceDelete 函数:
$user->forceDelete();
检测一个给定的模型实例是否被软删除,可以使用 trashed 函数:
if($user->trashed()){//}
查询范围
范围允许您容易在模型中重用查询逻辑。定义一个范围,简单的用 scope 为模型添加前缀
classUserextendsEloquent{publicfunction scopePopular($query){return $query->where('votes','>',100);}}
使用一个查询范围
$users =User::popular()->orderBy('created_at')->get();
使用参数
classUserextendsEloquent{publicfunction scopeOfType($query, $type){return $query->whereType($type);}}
然后在范围函数调用中传递参数:
$users =User::ofType('member')->get();
结束
[转]Laravel 4之Eloquent ORM的更多相关文章
- Laravel 数据库操作 Eloquent ORM
laravel 操作数据库一般都使用它的Eloquent ORM才操作 建立模型 <?php namespace App; use Illuminate\Database\Eloquent\Mo ...
- Laravel数据库操作 Eloquent ORM
模型首先在App目录下建立student的文件夹 里面放上 Student.php 且需要继承基类Model //允许批量赋值的字段// protected $fillable = ['name',' ...
- Laravel Eloquent ORM
Eloquent ORM 简介 基本用法 集体赋值 插入.更新.删除 软删除 时间戳 查询范围 关系 查询关系 预先加载 插入相关模型 触发父模型时间戳 与数据透视表工作 集合 访问器和调整器 日期调 ...
- [Laravel] 03 - DB facade, Query builder & Eloquent ORM
连接数据库 一.Outline 三种操作数据库的方式. 二.Facade(外观)模式 Ref: 解读Laravel,看PHP如何实现Facade? Facade本质上是一个“把工作推给别人做的”的类. ...
- laravel 5.1 使用Eloquent ORM 操作实例
Laravel 的 Eloquent ORM 提供了更优雅的ActiveRecord 实现来和数据库的互动. 每个数据库表对应一个模型文件. 数据库配置 .env文件(也可以直接修改config/da ...
- laravel通过Eloquent ORM实现CURD
//Eloquent ORM public function orm1() { //all(); 返回所有数据: /*$students=Student::all(); dd($students);* ...
- laravel Eloquent ORM联合查询出现Class not found,就算在Moel中存在这个类
今天发现一个坑,在处理Eloquent ORM的联合查询时,一直报错Class 'AdminGroup' not found ,可是我的项目中明明存在这个类,如下 这是我的模型类: 它们的控制器方法: ...
- laravel框架总结(八) -- ORM模型
ORM模型简介 1>什么是ORM? ORM,即 Object-Relational Mapping(对象关系映射),它的作用是在关系型数据库和业务实体对象之间作一个映射,这样,我们在操作具体的 ...
- Eloquent ORM笔记
基本操作 新增 $user = new User; $user->name = 'John'; $user->save(); $insertedId = $user->id;//从对 ...
随机推荐
- 网络测试工具netperf
Netperf是一种网络性能的测量工具,主要针对基于TCP或UDP的传输.Netperf根据应用的不同,可以进行不同模式的网络性能测试,即批量数据传输(bulk data transfer)模式和请求 ...
- iOS应用性能调优的25个建议和技巧【转】
转载自:http://blog.jobbole.com/37984/ 首页 最新文章 资讯 程序员 设计 IT技术 创业 在国外 营销 趣文 特别分享 更多 > - Navigation - ...
- 阿里云 RDS 怎么保证高可用性
RDS在系统构建之初,从网络到硬件再到系统都是基于高可用设计,他可以做到故障30秒无缝转移,对应用完全透明. 当一个数据库实例发生故障时, 另一个会立即顶上,而且对应用是完全透明的.你无需变更应用的连 ...
- Objective-C set/get方法
主要内容set get方法的使用 关键字 @property 全自动生成set get方法 // 类的声名 @interface People : NSObject{ int _age; // 成员变 ...
- OpenGL ES 2.0 限定符
限定符 说明 作用 attribute 一般用于各个顶点各不相同的量,如顶点位置.颜色等 属性限定符,修饰的变量用来接收渲染管线传递进顶点着色器的当前顶点的各种属性值. 只能用来修饰符点数标量,浮点数 ...
- C/C++中的const int*和int * const
代码: #include <iostream> using namespace std; int main(){ const int *p; ; p = &a; a = ; cou ...
- w530 在ubuntu 12.04 _x64 背光调节方法
So to get the screen brightness keys working with your Nvidia graphics card, create a file in the xo ...
- VS2015试验随手记
1.第一次安装时,未完整安装,没有安装MFC,导致可以创建MFC工程,但是不能编译 解决办法,修改安装,加入MFC 2.学习创建windows runtime component,第一次使用,可以得到 ...
- 继刚接触play framework后,一些心得
我是个小菜鸟,我这些体会跟心得纯属个人观点,仅供参考,勿喷,我想记录下学习的历程,不断成长 在play2.0的框架里面 用到的最多的语言就是scala,对于习惯了java语言的我们来说 看这些语言 ...
- 一个Restful Api的访问控制方法
最近在做的两个项目,都需要使用Restful Api,接口的安全性和访问控制便成为一个问题,看了一下别家的API访问控制办法. 新浪的API访问控制使用的是AccessToken,有两种方式来使用该A ...