fix
This commit is contained in:
		| @@ -204,8 +204,15 @@ func (r *GormArticleRepository) Search(ctx context.Context, query *repoQueries.S | |||||||
| 	} | 	} | ||||||
| 	 | 	 | ||||||
| 	if query.CategoryID != "" { | 	if query.CategoryID != "" { | ||||||
|  | 		// 如果指定了分类ID,只查询该分类的文章(包括没有分类的文章,当CategoryID为空字符串时) | ||||||
|  | 		if query.CategoryID == "null" || query.CategoryID == "" { | ||||||
|  | 			// 查询没有分类的文章 | ||||||
|  | 			dbQuery = dbQuery.Where("category_id IS NULL OR category_id = ''") | ||||||
|  | 		} else { | ||||||
|  | 			// 查询指定分类的文章 | ||||||
| 			dbQuery = dbQuery.Where("category_id = ?", query.CategoryID) | 			dbQuery = dbQuery.Where("category_id = ?", query.CategoryID) | ||||||
| 		} | 		} | ||||||
|  | 	} | ||||||
| 	 | 	 | ||||||
| 	if query.AuthorID != "" { | 	if query.AuthorID != "" { | ||||||
| 		dbQuery = dbQuery.Where("author_id = ?", query.AuthorID) | 		dbQuery = dbQuery.Where("author_id = ?", query.AuthorID) | ||||||
| @@ -270,13 +277,23 @@ func (r *GormArticleRepository) ListArticles(ctx context.Context, query *repoQue | |||||||
| 	} | 	} | ||||||
| 	 | 	 | ||||||
| 	if query.CategoryID != "" { | 	if query.CategoryID != "" { | ||||||
|  | 		// 如果指定了分类ID,只查询该分类的文章(包括没有分类的文章,当CategoryID为空字符串时) | ||||||
|  | 		if query.CategoryID == "null" || query.CategoryID == "" { | ||||||
|  | 			// 查询没有分类的文章 | ||||||
|  | 			dbQuery = dbQuery.Where("category_id IS NULL OR category_id = ''") | ||||||
|  | 		} else { | ||||||
|  | 			// 查询指定分类的文章 | ||||||
| 			dbQuery = dbQuery.Where("category_id = ?", query.CategoryID) | 			dbQuery = dbQuery.Where("category_id = ?", query.CategoryID) | ||||||
| 		} | 		} | ||||||
|  | 	} | ||||||
| 	 | 	 | ||||||
| 	if query.TagID != "" { | 	if query.TagID != "" { | ||||||
| 		// 通过标签关联表筛选 | 		// 如果指定了标签ID,只查询有关联该标签的文章 | ||||||
| 		dbQuery = dbQuery.Joins("JOIN article_tag_relations ON articles.id = article_tag_relations.article_id"). | 		// 使用子查询而不是JOIN,避免影响其他查询条件 | ||||||
| 			Where("article_tag_relations.tag_id = ?", query.TagID) | 		subQuery := r.db.WithContext(ctx).Table("article_tag_relations"). | ||||||
|  | 			Select("article_id"). | ||||||
|  | 			Where("tag_id = ?", query.TagID) | ||||||
|  | 		dbQuery = dbQuery.Where("id IN (?)", subQuery) | ||||||
| 	} | 	} | ||||||
| 	 | 	 | ||||||
| 	if query.Title != "" { | 	if query.Title != "" { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user