web_article

This commit is contained in:
2024-12-28 20:11:15 +08:00
parent ed450130da
commit 935420d43a
2 changed files with 3 additions and 37 deletions

View File

@@ -202,7 +202,7 @@ var ArticleItems = &graphql.Field{
}
sql = fmt.Sprintf(`
WITH RankedArticles AS (%s)
SELECT * %s %s %s FROM web_article INNER JOIN(
SELECT web_article.* %s %s %s FROM web_article INNER JOIN(
SELECT id, row_num FROM RankedArticles %s
) AS LimitedRanked ON LimitedRanked.id = web_article.id
ORDER BY LimitedRanked.row_num ASC LIMIT %d
@@ -214,40 +214,6 @@ var ArticleItems = &graphql.Field{
return nil, err
}
//// 试图使用GORM语法整理
//subQuery := db.Table("web_article").Select([]string{
// "web_article.*",
// fmt.Sprintf("ROW_NUMBER() OVER(ORDER BY web_article.%s %s) AS row_num", p.Args["sort"], p.Args["order"]),
//}).Where("category_id = 10").Limit(limit)
//// 筛选条件
//for _, format := range []string{"id", "style", "device", "orientation", "era", "category_id", "tags"} {
// if p.Args[format] != nil {
// subQuery = subQuery.Where(fmt.Sprintf("%s = ?", format), p.Args[format])
// }
//}
//// 按指定用户点赞筛选
//if p.Args["praise"] != nil {
// subQuery = subQuery.Joins("JOIN web_praise AS wp ON wp.praise_id = web_article.id AND wp.user_id = ? AND wp.type = 0", p.Args["praise"])
//}
//// 按指定用户收藏筛选
//if p.Args["collect"] != nil {
// subQuery = subQuery.Joins("JOIN web_collect AS wc ON wc.collect_id = web_article.id AND wc.user_id = ? AND wc.type = 0", p.Args["collect"])
//}
//var _select []string = []string{"*"}
//if funk.Contains(fields, "text_count") {
// _select = append(_select, "(SELECT COUNT(*) FROM web_images wi WHERE wi.article_id = web_article.id AND wi.text != '') AS text_count")
//}
//if funk.Contains(fields, "collect") {
// _select = append(_select, fmt.Sprintf("(SELECT COUNT(*) FROM web_collect wc WHERE wc.collect_id = web_article.id AND wc.user_id = %d AND wc.type = 0) AS is_collect", user_id))
//}
//if funk.Contains(fields, "praise") {
// _select = append(_select, fmt.Sprintf("(SELECT COUNT(*) FROM web_praise wp WHERE wp.praise_id = web_article.id AND wp.user_id = %d AND wp.type = 0) AS is_praise", user_id))
//}
//if err := db.Table("(?) AS limited_imgs", subQuery).Select(_select).Scan(&articles).Error; err != nil {
// fmt.Println("获取文章列表失败", err)
// return nil, err
//}
var items = ListItem(p.Info.FieldASTs[0].SelectionSet.Selections)
if funk.Contains(items, "views") {
type ApiResponse struct {