Laravel如何在单个表上添加所有总数
我正在尝试构建一个查询,但有问题。我想编写一个代码,每行都在一个表上都有全部计数。我将首先描述
我将查询总数:
$count = Rating::whereIN('book_id',Books::select('id'))->count();
//the all total counts of this ratings table is 12
第二是在与作者的评分中查询每行计数:
return $books = Books::withCount('rating')
->with(['author:id,user_id','author.user:id,name,email'])
->get();
输出:
[
{
"id": 1,
"created_at": "2022-06-15T09:59:10.000000Z",
"updated_at": "2022-06-15T09:59:10.000000Z",
"author_id": 2,
"title": "vel",
"name": "Qui odit eum ea recusandae rem officiis.",
"rating_count": 5,
"author": {
"id": 2,
"user_id": 1,
"user": {
"id": 1,
"name": "Joshua Weber",
"email": "[email protected]"
}
}
},
{
"id": 2,
"created_at": "2022-06-15T09:59:10.000000Z",
"updated_at": "2022-06-15T09:59:10.000000Z",
"author_id": 1,
"title": "atque",
"name": "Beatae tenetur modi rerum dolore facilis eos incidunt.",
"rating_count": 7,
"author": {
"id": 1,
"user_id": 5,
"user": {
"id": 5,
"name": "Miss Destinee Nitzsche III",
"email": "[email protected]"
}
}
}
]
您可以在此代码中看到每行拥有他们的 rating_count_count_count in <代码> ID:1 具有 rating_count 5,在ID中:2
在总计12时具有评分计数7。
现在我的问题的目的是我想要在book :: withCount
中添加 addSelect()
我想添加第一个查询我写的。因此,每一行的总书籍总数为12,
但我尝试了此代码,但它给出了一个错误:
return $books = Books::withCount('rating')
->with(['author:id,user_id','author.user:id,name,email'])
->addSelect(['total_books'=>Rating::whereIN('book_id',Books::select('id'))->count()])
->get();
错误:
SQLSTATE[42S22]: Column not found: 1054 Unknown column '105' in 'field list' (SQL: select `books`.*, (select count(*) from `ratings` where `books`.`id` = `ratings`.`book_id`) as `rating_count`, `105` from `books`)
这是我的表格:(我没有在作者和评分中添加ROW create_at和updated_ad),
my table authors
id | user_id
1 | 1
2 | 5
my table books
id | created_at | updated_at | author_id | title | name
1 | | | 1 | vel | Qui odit eum ea recusandae rem officiis
2 | | | 2 | atque | Beatae tenetur modi rerum dolore facilis eos incidunt.
my table ratings
id | rating | book_id
1 | 5 | 1
2 | 4 | 1
3 | 4 | 1
4 | 3 | 1
5 | 2 | 1
6 | 1 | 1
7 | 1 | 1
8 | 5 | 2
9 | 4 | 2
10 | 3 | 2
11 | 3 | 2
12 | 1 | 2
这是我的模型
模型作者
class Author extends Model
{
use HasFactory;
public function books(){
return $this->hasMany(Books::class);
}
public function User(){
return $this->belongsTo(User::class);
}
}
模型模型书籍。
class Books extends Model
{
use HasFactory;
protected $casts = [
'created_at' => 'datetime',
];
public function rating(){
return $this->hasMany(Rating::class,'book_id');
}
public function author(){
return $this->belongsTo(Author::class);
}
}
i am trying to build a single query but something is wrong. i want to write a code that each row have a all total count on a one table. i will describe
first i will query the total counts :
$count = Rating::whereIN('book_id',Books::select('id'))->count();
//the all total counts of this ratings table is 12
second is querying the books count each rows in ratings with authors :
return $books = Books::withCount('rating')
->with(['author:id,user_id','author.user:id,name,email'])
->get();
the output of this :
[
{
"id": 1,
"created_at": "2022-06-15T09:59:10.000000Z",
"updated_at": "2022-06-15T09:59:10.000000Z",
"author_id": 2,
"title": "vel",
"name": "Qui odit eum ea recusandae rem officiis.",
"rating_count": 5,
"author": {
"id": 2,
"user_id": 1,
"user": {
"id": 1,
"name": "Joshua Weber",
"email": "[email protected]"
}
}
},
{
"id": 2,
"created_at": "2022-06-15T09:59:10.000000Z",
"updated_at": "2022-06-15T09:59:10.000000Z",
"author_id": 1,
"title": "atque",
"name": "Beatae tenetur modi rerum dolore facilis eos incidunt.",
"rating_count": 7,
"author": {
"id": 1,
"user_id": 5,
"user": {
"id": 5,
"name": "Miss Destinee Nitzsche III",
"email": "[email protected]"
}
}
}
]
you can see in this code each row has own their rating_count in id:1
has rating_count 5 and in id:2
has rating count 7 when summing them total of 12.
now the point of my problem is i want to add addSelect()
in the Book::withCount
i want to add the first query i wrote. so each row has a total books of 12
i tried this code but it gives a error:
return $books = Books::withCount('rating')
->with(['author:id,user_id','author.user:id,name,email'])
->addSelect(['total_books'=>Rating::whereIN('book_id',Books::select('id'))->count()])
->get();
the error:
SQLSTATE[42S22]: Column not found: 1054 Unknown column '105' in 'field list' (SQL: select `books`.*, (select count(*) from `ratings` where `books`.`id` = `ratings`.`book_id`) as `rating_count`, `105` from `books`)
here is my tables: ( i did not add row created_at and updated_ad in authors and ratings )
my table authors
id | user_id
1 | 1
2 | 5
my table books
id | created_at | updated_at | author_id | title | name
1 | | | 1 | vel | Qui odit eum ea recusandae rem officiis
2 | | | 2 | atque | Beatae tenetur modi rerum dolore facilis eos incidunt.
my table ratings
id | rating | book_id
1 | 5 | 1
2 | 4 | 1
3 | 4 | 1
4 | 3 | 1
5 | 2 | 1
6 | 1 | 1
7 | 1 | 1
8 | 5 | 2
9 | 4 | 2
10 | 3 | 2
11 | 3 | 2
12 | 1 | 2
here is my models
model Authors
class Author extends Model
{
use HasFactory;
public function books(){
return $this->hasMany(Books::class);
}
public function User(){
return $this->belongsTo(User::class);
}
}
model Books
class Books extends Model
{
use HasFactory;
protected $casts = [
'created_at' => 'datetime',
];
public function rating(){
return $this->hasMany(Rating::class,'book_id');
}
public function author(){
return $this->belongsTo(Author::class);
}
}
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
我不太了解 total_books的计数的查询
上述查询本质上是评级表中的记录计数表。由于评分中的记录表将具有 book_id (假设已定义完整性约束)的有效值,这意味着对于评级中的任何行/记录表 book_id 中包含的价值将是 book 表中现有记录的 id 。
因此,
其中('book_id',book :: select('id'))
是不必要的。您可以做到,然后可以使用 addSelect
或使用 selectraw
total_books 可能被称为 total_ratings < /strong>
如果您仍然想拥有,其中约束(这不是必要的),则
可以生成SQL
或使用 selectraw
I don't quite understand the query for count of total_books
The above query is essentially the count of records in the ratings table. Since the records in ratings table will have a valid value for book_id (assuming integrity constraints are defined) which means that for any row/record in the ratings table the value contained in book_id will be an id of an existing record in books table.
So the
whereIn('book_id', Book::select('id'))
is unnecessary. You can do justThen you can have your composite query with addSelect as
Or using selectRaw
The total_books should probably be named as total_ratings
If you still want to have your whereIn constraint (which isn't necessary) you can
The above will generate an sql
OR with selectRaw
正如我评论的那样,您可以先计数总评分,然后将其重新分配到
$ book
实例。如果不需要,请不要让SQL查询为每个获取的行计算。As I commented, you can count total ratings first, then reassign it to
$book
instance. Don't let SQL query calculates for every fetched rows if unnecessary.