首页 >

mysql 如何查询拼接,Laravel使用模型关联关系返回指定列 – 数据库 – 前端,mysql 月份去0

mysql存储过程参数,linux mysql 更改路径,修改mysql表字段格式,mysql属于编程语言吗,mysql网络设置,mysql 月份去0mysql 如何查询拼接,Laravel使用模型关联关系返回指定列 - 数据库 - 前端,mysql 月份去0

今天大家说一说,在Laravel中,如何关联模型,以及制定返回列,以精简返回数据。

学习时间

假如有两个模型 User 和 Post,一个用户会发布多个post,也就是一对多的关联关系。在User模型中,指定此关系:

public function post(){ return $this->hasmany(‘Post’); }

反过来,在Post模型中,必然有一个发布者,是一对一的映射:

public function user(){ return $this->belongsTo(‘User’); }

现在假如有一个查询,获取所有的帖子,并返回发布者的信息。如下:

public function getAllPosts() { return Post::with(‘user’)->get(); }

这样在返回值中,就可以使用 $post->user 返回 User 模型,并访问其属性和方法。经过框架整合后的 SQL 语句大概是这样的:

select * from `posts` select * from `users` where `users`.`id` in (<1>, <2>)

显然,第二条SQL语句,返回了user表的所有列,数据量有可能很大。是否可以返回指定列呢?这样可以精简输出,减少MySQL的传输负荷。

with语句

模型的with语句用于调用模型内声明的关联关系,其实它接收一个数组,可以在查询时关联多张表,同时支持一个闭包,用于对关联表的查询语句进行裁切。

如上一节要指定user表的列,可以这样写:

Post::with(array(‘user’=>function($query){ $query->select(‘id’,’username’); }))->get();

闭包内$query拼接SQL语句,并指定 select 选取的列,那么框架生成的SQL语句,就只会返回 id,username 列。

关联关系

大家注意到,在关联关系的声明上,第一节仅使用了 belongTo,hasMany 这样的属性,其实还可以链式调用。这样对于所有使用 with 语句关联的模型查询,都会生效。

没错儿,接着关联关系用下去。比如Post模型内:

public function user() { return $this->belongsTo(‘User’)->select(array(‘id’, ‘username’)); }

特殊性

在Laravel5.5及以上的版本,支持在使用with语句的使用,按照格式书写返回指定列。

Post::with(‘user:id,username’)->get();

低版本可就没有那么好运气了!:-(

写在最后

本文通过2种确切可用的方式,裁剪了关联模型返回列的内容。

在实际代码中,第一种使用闭包修剪SQL语句,用途较为广泛。

第二种方式影响全局,一般不推荐。

第三种则是第一种的变体,但是对版本有要求。

Happy coding 🙂

偶是 @程序员小助手 ,持续分享编程知识,欢迎关注。

mysql存储过程参数,linux mysql 更改路径,修改mysql表字段格式,mysql属于编程语言吗,mysql网络设置,mysql 月份去0mysql 如何查询拼接,Laravel使用模型关联关系返回指定列 - 数据库 - 前端,mysql 月份去0


mysql 如何查询拼接,Laravel使用模型关联关系返回指定列 - 数据库 - 前端,mysql 月份去0
  • mysql 查询空列,Mysql的字段设置为null有什么优点呢 - 数据库 - 前端,centos 查看mysql进程
  • mysql 查询空列,Mysql的字段设置为null有什么优点呢 - 数据库 - 前端,centos 查看mysql进程 | mysql 查询空列,Mysql的字段设置为null有什么优点呢 - 数据库 - 前端,centos 查看mysql进程 ...

    mysql 如何查询拼接,Laravel使用模型关联关系返回指定列 - 数据库 - 前端,mysql 月份去0
  • mysql大小表查询优化,mysql全文索引如何支持中文 - 数据库 - 前端,mysql改语句
  • mysql大小表查询优化,mysql全文索引如何支持中文 - 数据库 - 前端,mysql改语句 | mysql大小表查询优化,mysql全文索引如何支持中文 - 数据库 - 前端,mysql改语句 ...

    mysql 如何查询拼接,Laravel使用模型关联关系返回指定列 - 数据库 - 前端,mysql 月份去0
  • declmal是什么数据类型 - 数据库 - 前端|
  • declmal是什么数据类型 - 数据库 - 前端| | declmal是什么数据类型 - 数据库 - 前端| ...