laravel中,orm全称“Object-Relational Mapping”,意思为“对象关系映射”,它的作用是在关系型数据库和业务实体对象之间作一个映射;这样在操作业务对象时,不需和复杂的SQL语句打交道,只需操作对象的属性和方法。
本教程操作环境:windows7系统、Laravel6版、Dell G3电脑。
什么叫 ORM
ORM,全称 Object-Relational Mapping(对象关系映射),它的作用是在关系型数据库和业务实体对象之间作一个映射,这样,我们在操作具体的业务对象时,就不需要再去和复杂的SQL语句打交道,只需简单的操作对象的属性和方法即可。
ORM 实现方式
两种最常见的实现方式是 ActiveRecord 和 DataMapper (laravel 中使用的是前者)
ActiveRecord(非常流行) 中模型与数据表一一对应,
DataMapper 中模型与数据表是完全分离的。
Laravel 的 Eloquent ORM 使用 ActiveRecord 实现方式,每一个 Eloquent 模型类对应着数据库中的一张表,我们通过调用模型类的相应方法实现对数据库的增删改查。
理解两个魔法函数 __call () 和 __callStatic ()
class Test{
//动态调用的时候 没有找到此函数 则执行__call() 方法
public function __call($method, $parameters){
echo 22222222222;
return (new Rest)->$method(...$parameters);
}
//静态调用的时候 没有找到此函数 则执行__callStatic()方法
public static function __callStatic($method, $parameters){
echo 1111111111;
return (new static)->$method(...$parameters);
}
}
class Rest{
public function foo($name , $age){
echo 333;
dump($name,$age);
}
}
//先调用了__callStatic(), 在调用__call(), 然后调用 foo();
Test::foo('张三',17);
//只调用了 __call(), 然后调用 foo();
(new Test())->foo('李四',16);die;
理解了前面两个魔法函数 对于 laravel Eloqument ORM 中的难点 也就理解了,我们来看一下 Model 中的源码
/**
* Handle dynamic method calls into the model. * * @param string $method
* @param array $parameters
* @return mixed
*/public function __call($method, $parameters)
{
if (in_array($method, ['increment', 'decrement'])) {
return $this->$method(...$parameters);
}
return $this->newQuery()->$method(...$parameters);
}
/**
* Handle dynamic static method calls into the method. * * @param string $method
* @param array $parameters
* @return mixed
*/public static function __callStatic($method, $parameters)
{
return (new static)->$method(...$parameters);
}
new static 返回的是调用者的实例, new self () 返回的是自身实例
使用 eloqument 查询的时候
1
$list = Politician::where('party_id', 1)->count();
where 方法不在 Model 中 会先执行 callStatic()函数 获取 App\Models\Politician 实例 ,再执行 call () , 在 $this->newQuery () 返回实例中寻找 where () count()等方法。
细看一下 newQuery () 方法 这里面返回的实例。 理解了这两个魔术函数 对 laravel 中 orm 的实现的难点就攻克了。
laravel 中的查询构造器
1
$list = DB::table('categoty')->get();
Eloquent ORM 实际上是对 查询构造进行了一次封装,可以更方便的去操作。 查询构造器的源码大家有兴趣的话可以看一看