初始化

This commit is contained in:
lhx
2025-12-12 10:57:31 +08:00
commit f8e85beba1
38 changed files with 2146 additions and 0 deletions

56
app/api/section_data.py Normal file
View File

@@ -0,0 +1,56 @@
"""断面数据接口"""
from fastapi import APIRouter, Depends
from sqlalchemy.orm import Session
from app.core.database import get_tunnel_db
from app.core.logging_config import get_logger
from app.schemas.section_data import SectionDataBatchImport, SectionDataQuery
from app.schemas.common import BatchImportResponse
from app.servives.section_data_service import SectionDataService
router = APIRouter(prefix="/section_data", tags=["断面数据"])
logger = get_logger(__name__)
@router.post("/import", response_model=BatchImportResponse)
async def batch_import(
request: SectionDataBatchImport,
db: Session = Depends(get_tunnel_db)
):
"""批量导入断面数据"""
logger.info(f"断面数据导入请求: account_id={request.account_id}, 数据量={len(request.data)}")
return SectionDataService.batch_import(db, request.account_id, request.data)
@router.post("/query")
async def query(
request: SectionDataQuery,
db: Session = Depends(get_tunnel_db)
):
"""查询断面数据"""
logger.info(f"断面数据查询请求: {request}")
items, total = SectionDataService.query(db, request)
return {
"total": total,
"page": request.page,
"page_size": request.page_size,
"items": items
}
@router.post("/query_by_department")
async def query_by_department(
request: SectionDataQuery,
db: Session = Depends(get_tunnel_db)
):
"""根据department_id查询断面数据"""
logger.info(f"根据department_id查询断面数据: {request}")
params = SectionDataQuery(
account_id=request.account_id,
department_id=request.department_id,
page=request.page,
page_size=request.page_size
)
items, total = SectionDataService.query(db, params)
return {
"total": total,
"page": request.page,
"page_size": request.page_size,
"items": items
}