Files
mp-qvyun/backend/pkg/db/db.go
2024-12-02 11:29:15 +08:00

29 lines
526 B
Go

package db
import (
"context"
"database/sql"
"fmt"
"backend/common/consts"
"github.com/go-jet/jet/v2/qrm"
)
func FromContext(ctx context.Context, db *sql.DB) qrm.DB {
if tx, ok := ctx.Value(consts.CtxKeyTx).(*sql.Tx); ok {
return tx
}
return db
}
func TruncateAllTables(ctx context.Context, db *sql.DB, tableName ...string) error {
for _, name := range tableName {
sql := fmt.Sprintf("TRUNCATE TABLE %s CASCADE", name)
if _, err := db.ExecContext(ctx, sql); err != nil {
return err
}
}
return nil
}