19cc7a778c
- Deleted old gRPC service definitions in `game_grpc.pb.go` and `public.go`. - Added new API server implementations for objectstory, player, and shop services. - Introduced configuration files for new APIs in `etc/*.yaml`. - Created main entry points for each service in `objectstory.go`, `player.go`, and `shop.go`. - Removed unused user update handler and user API files. - Added utility functions for context management and HTTP header parsing. - Introduced PostgreSQL backup configuration in `backup/postgreSql.yaml`.
37 lines
1.5 KiB
SQL
37 lines
1.5 KiB
SQL
CREATE TABLE reviews
|
|
(
|
|
id BIGINT PRIMARY KEY,
|
|
order_id BIGINT NOT NULL,
|
|
from_user_id BIGINT NOT NULL,
|
|
from_user_name VARCHAR(100) NOT NULL,
|
|
from_user_avatar TEXT,
|
|
to_user_id BIGINT NOT NULL,
|
|
rating SMALLINT NOT NULL,
|
|
content TEXT,
|
|
sealed BOOLEAN DEFAULT TRUE,
|
|
created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
|
|
unsealed_at TIMESTAMPTZ,
|
|
CONSTRAINT chk_rating_range CHECK (rating >= 1 AND rating <= 5),
|
|
UNIQUE (order_id, from_user_id)
|
|
);
|
|
|
|
-- 基础索引
|
|
CREATE INDEX idx_reviews_order ON reviews (order_id);
|
|
CREATE INDEX idx_reviews_to_user ON reviews (to_user_id, created_at
|
|
CREATE INDEX idx_reviews_to_user ON reviews(to_user_id, created_at DESC)
|
|
WHERE sealed = FALSE;
|
|
CREATE INDEX idx_reviews_from_user ON reviews (from_user_id);
|
|
|
|
-- 三元组索引用于评价内容搜索
|
|
CREATE INDEX idx_reviews_content_trgm ON reviews USING gin (content gin_trgm_ops)
|
|
WHERE sealed = FALSE AND content IS NOT NULL;
|
|
|
|
-- 复合索引优化用户评价列表
|
|
CREATE INDEX idx_reviews_to_user_rating ON reviews (to_user_id, rating DESC, created_at DESC)
|
|
WHERE sealed = FALSE;
|
|
|
|
-- 复合索引优化订单评价查询
|
|
CREATE INDEX idx_reviews_order_sealed ON reviews (order_id, sealed);
|
|
|
|
-- 评分统计索引
|
|
CREATE INDEX idx_reviews_rating_created ON reviews (rating, created_at DESC) WHERE sealed = FALSE; |