经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » PHP » 查看文章
laravel5.1框架model类查询的实现方法
来源:jb51  时间:2019/10/9 8:35:18  对本文有异议

laravel框架model类查询实现:

User::where(['uid'=8])->get();

User类继承自Model类:Illuminate\Database\Eloquent\Model

当User类静态调用where方法时,自动调用了Model里的魔术方法:

  1. public static function __callStatic($method, $parameters)
  2. {
  3. $instance = new static; //这里的$instance就是User类的实例对象
  4.  
  5. return call_user_func_array([$instance, $method], $parameters);
  6. }

相当于调用了user对象的where方法,这时就又调用了魔术方法:

  1. public function __call($method, $parameters)
  2. {
  3. if (in_array($method, ['increment', 'decrement'])) {
  4. return call_user_func_array([$this, $method], $parameters);
  5. }
  6.  
  7. $query = $this->newQuery(); //返回Illuminate\Database\Eloquent\Builder对象
  8.  
  9. return call_user_func_array([$query, $method], $parameters);
  10. }

相当于调用Illuminate\Database\Eloquent\Builder对象里的where方法和get方法,这两个方法里其实

其实是封装调用了Illuminate\Database\Query\Builder对象里的where方法和get方法->get方法里调用了runselect方法

runSelect方法:

  1. /**
  2. * Run the query as a "select" statement against the connection.
  3. *
  4. * @return array
  5. */
  6. protected function runSelect()
  7. {
  8. return $this->connection->select($this->toSql(), $this->getBindings(), ! $this->useWritePdo); //调用connection 对象的select方法
  9. }

再看connection对象是怎么传到Illuminate\Database\Eloquent\Builder类实例里的:

Model类的newQuery方法:

  1. /**
  2. * Get a new query builder for the model's table.
  3. *
  4. * @return \Illuminate\Database\Eloquent\Builder
  5. */
  6. public function newQuery()
  7. {
  8. $builder = $this->newQueryWithoutScopes();
  9.  
  10. return $this->applyGlobalScopes($builder);
  11. }

Model类的newQueryWithoutScopes方法:

  1. /**
  2. * Get a new query builder that doesn't have any global scopes.
  3. *
  4. * @return \Illuminate\Database\Eloquent\Builder|static
  5. */
  6. public function newQueryWithoutScopes()
  7. {
  8. $builder = $this->newEloquentBuilder(
  9. $this->newBaseQueryBuilder() //这个方法返回
  10. );
  11.  
  12. // Once we have the query builders, we will set the model instances so the
  13. // builder can easily access any information it may need from the model
  14. // while it is constructing and executing various queries against it.
  15. return $builder->setModel($this)->with($this->with);
  16. }

Model类的newBaseQueryBuilder方法实现

  1. /**
  2. * Get a new query builder instance for the connection.
  3. *
  4. * @return \Illuminate\Database\Query\Builder
  5. */
  6. protected function newBaseQueryBuilder()
  7. {
  8. $conn = $this->getConnection(); \\连接数据库并返回connection对象
  9.  
  10. $grammar = $conn->getQueryGrammar();
  11.  
  12. return new QueryBuilder($conn, $grammar, $conn->getPostProcessor()); //Illuminate\Database\Query\Builder
  13.  
  14. }

Model类的$resolver属性(连接解析器)的设定是通过

Illuminate\Database\DatabaseServiceProvider 里的boot方法设置的

这样Model类的getConnection方法实际调用的DatabaseManager类的connection方法,返回connection类实例

如何创建的数据库连接:

Model类getConnection方法->DatabaseManager类connection方法->

->ConnectionFactory类的createSingleConnection()

  1. /**
  2. * Create a single database connection instance.
  3. *
  4. * @param array $config
  5. * @return \Illuminate\Database\Connection
  6. */
  7. protected function createSingleConnection(array $config)
  8. {
  9. //创建连接器对象并连接数据库返回pdo对象
  10. $pdo = $this->createConnector($config)->connect($config);
  11. //传入PDO对象、并返回connection对象,connection对象负责查询数据库
  12. return $this->createConnection($config['driver'], $pdo, $config['database'], $config['prefix'], $config);
  13.  
  14. }

以上这篇laravel5.1框架model类查询的实现方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持w3xue。

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号