Skip to content

Commit

Permalink
perf: db query index miss
Browse files Browse the repository at this point in the history
  • Loading branch information
trim21 committed Oct 15, 2024
1 parent 1f40e57 commit 71ba130
Showing 1 changed file with 4 additions and 20 deletions.
24 changes: 4 additions & 20 deletions internal/tag/mysql_repo.go
Original file line number Diff line number Diff line change
Expand Up @@ -16,11 +16,8 @@ package tag

import (
"context"
"database/sql"
"errors"

"github.com/jmoiron/sqlx"
"github.com/trim21/errgo"
"go.uber.org/zap"

"github.com/bangumi/server/dal/query"
Expand All @@ -38,31 +35,18 @@ type mysqlRepo struct {
}

func (r mysqlRepo) Get(ctx context.Context, id model.SubjectID) ([]Tag, error) {
// this is not necessary information for query data, but it will help mysql to hit cache
var subjectType model.SubjectType
err := r.db.QueryRowContext(ctx, `
select chii_subjects.subject_type_id from chii_subjects where subject_id = ?
`, id).Scan(&subjectType)
if err != nil {
if errors.Is(err, sql.ErrNoRows) {
return []Tag{}, nil
}

return nil, errgo.Trace(err)
}

var s []struct {
Tid uint `db:"tlt_tid"`
Name string `db:"tag_name"`
TotalCount uint `db:"tag_results"`
}

err = r.db.SelectContext(ctx, &s, `
err := r.db.SelectContext(ctx, &s, `
select tlt_tid, tag_name, tag_results
from chii_tag_neue_list
inner join chii_tag_neue_index on tlt_tid = tag_id and tlt_type = ?
inner join chii_tag_neue_index on tlt_tid = tag_id
where tlt_uid = 0 and tag_cat = ? and tlt_mid = ?
`, subjectType, CatSubject, id)
`, CatSubject, id)
if err != nil {
return nil, err
}
Expand All @@ -89,7 +73,7 @@ func (r mysqlRepo) GetByIDs(ctx context.Context, ids []model.SubjectID) (map[mod
q, v, err := sqlx.In(`
select tlt_tid, tag_name, tag_results, tlt_mid
from chii_tag_neue_list
inner join chii_tag_neue_index on tlt_tid = tag_id and tlt_type = tag_type
inner join chii_tag_neue_index on tlt_tid = tag_id
where tlt_uid = 0 and tag_cat = ? and tlt_mid IN (?)
`, CatSubject, ids)
if err != nil {
Expand Down

0 comments on commit 71ba130

Please sign in to comment.