Fundamental_Analysis/services/data-persistence-service/.sqlx/query-a487a815febf42b5c58fce44382f2d849f81b5831e733fc1d8faa62196f67dc9.json
Lv, Qi 21155bc4f8 feat(realtime): 接入前端实时报价并完善后端缓存
前端: 新增 RealTimeQuoteResponse 类型;新增 useRealtimeQuote Hook 并在报告页图表旁展示价格与时间戳(严格 TTL,无兜底)

FastAPI: 新增 GET /financials/{market}/{symbol}/realtime?max_age_seconds=.. 只读端点;通过 DataPersistenceClient 读取 Rust 缓存

Rust: 新增 realtime_quotes hypertable 迁移;新增 POST /api/v1/market-data/quotes 与 GET /api/v1/market-data/quotes/{symbol}?market=..;新增 DTO/Model/DB 函数;修正 #[api] 宏与路径参数;生成 SQLx 离线缓存 (.sqlx) 以支持离线构建

Python: DataPersistenceClient 新增 upsert/get 实时报价,并调整 GET 路径与参数

说明: TradingView 图表是第三方 websocket,不受我们缓存控制;页面数值展示走自有缓存通路,统一且可控。
2025-11-09 05:12:14 +08:00

79 lines
1.7 KiB
JSON

{
"db_name": "PostgreSQL",
"query": "\n SELECT symbol, trade_date, open_price, high_price, low_price, close_price, volume, pe, pb, total_mv\n FROM daily_market_data\n WHERE symbol = $1\n AND ($2::DATE IS NULL OR trade_date >= $2)\n AND ($3::DATE IS NULL OR trade_date <= $3)\n ORDER BY trade_date DESC\n ",
"describe": {
"columns": [
{
"ordinal": 0,
"name": "symbol",
"type_info": "Varchar"
},
{
"ordinal": 1,
"name": "trade_date",
"type_info": "Date"
},
{
"ordinal": 2,
"name": "open_price",
"type_info": "Numeric"
},
{
"ordinal": 3,
"name": "high_price",
"type_info": "Numeric"
},
{
"ordinal": 4,
"name": "low_price",
"type_info": "Numeric"
},
{
"ordinal": 5,
"name": "close_price",
"type_info": "Numeric"
},
{
"ordinal": 6,
"name": "volume",
"type_info": "Int8"
},
{
"ordinal": 7,
"name": "pe",
"type_info": "Numeric"
},
{
"ordinal": 8,
"name": "pb",
"type_info": "Numeric"
},
{
"ordinal": 9,
"name": "total_mv",
"type_info": "Numeric"
}
],
"parameters": {
"Left": [
"Text",
"Date",
"Date"
]
},
"nullable": [
false,
false,
true,
true,
true,
true,
true,
true,
true,
true
]
},
"hash": "a487a815febf42b5c58fce44382f2d849f81b5831e733fc1d8faa62196f67dc9"
}