当前位置: 首页 > news >正文

制作一个网站数据库怎么做的沧州网络运营公司

制作一个网站数据库怎么做的,沧州网络运营公司,佛山外贸网站推广,企业建设网站流程图1. 创建项目结构 首先,设计一个合理的项目结构。这里以三个Apps为例:users、items 和 orders。2. 项目结构 my_fastapi_project/ ├── main.py ├── app/ │ ├── __init__.py │ ├── users/ │ │ ├── __init__.py │ │ ├─…

1. 创建项目结构

首先,设计一个合理的项目结构。这里以三个Apps为例:users、items 和 orders。

2. 项目结构

my_fastapi_project/
├── main.py
├── app/
│   ├── __init__.py
│   ├── users/
│   │   ├── __init__.py
│   │   ├── models.py
│   │   ├── schemas.py
│   │   ├── crud.py
│   │   └── routes.py
│   ├── items/
│   │   ├── __init__.py
│   │   ├── models.py
│   │   ├── schemas.py
│   │   ├── crud.py
│   │   └── routes.py
│   ├── orders/
│   │   ├── __init__.py
│   │   ├── models.py
│   │   ├── schemas.py
│   │   ├── crud.py
│   │   └── routes.py
├── database.py
└── config.py

3. 配置数据库连接 (database.py)

from databases import Database
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy import create_engine, MetaDataDATABASE_URL = "sqlite:///./test.db"  # 使用SQLite作为示例数据库# 初始化数据库连接
database = Database(DATABASE_URL)
metadata = MetaData()
engine = create_engine(DATABASE_URL)Base = declarative_base()async def init_db():async with engine.begin() as conn:await conn.run_sync(Base.metadata.create_all)# 在实际部署中应更加谨慎地处理这一点
import asyncio
asyncio.run(init_db())

4. 定义配置 (config.py)

class Settings:openai_api_key: str = "your-openai-api-key"# 其他配置项...settings = Settings()

5. 每个App的具体实现

app/users/models.py - 用户模型定义

from sqlalchemy import Column, Integer, String
from ..database import Baseclass User(Base):__tablename__ = "users"id = Column(Integer, primary_key=True, index=True)username = Column(String, unique=True, index=True)email = Column(String, unique=True, index=True)

6. app/users/schemas.py - 用户Pydantic模式定义

from pydantic import BaseModelclass UserCreate(BaseModel):username: stremail: strclass UserSchema(UserCreate):id: intclass Config:orm_mode = True

7. app/users/crud.py - 用户CRUD操作

from sqlalchemy.orm import Session
from .models import User as UserModel
from .schemas import UserCreateasync def get_user(db: Session, user_id: int):return db.query(UserModel).filter(UserModel.id == user_id).first()async def create_user(db: Session, user: UserCreate):db_user = UserModel(**user.dict())db.add(db_user)await db.commit()await db.refresh(db_user)return db_user

8. app/users/routes.py - 用户路由定义

from fastapi import APIRouter, Depends, HTTPException
from sqlalchemy.orm import Session
from ..database import get_db_session
from .crud import get_user, create_user
from .schemas import UserCreate, UserSchemarouter = APIRouter()@router.get("/users/{user_id}", response_model=UserSchema)
async def read_user(user_id: int, db: Session = Depends(get_db_session)):db_user = await get_user(db, user_id=user_id)if db_user is None:raise HTTPException(status_code=404, detail="User not found")return db_user@router.post("/users/", response_model=UserSchema)
async def create_new_user(user: UserCreate, db: Session = Depends(get_db_session)):return await create_user(db=db, user=user)

9. 将所有路由注册到主应用 (main.py)

from fastapi import FastAPI
from app.users.routes import router as users_router
from app.items.routes import router as items_router
from app.orders.routes import router as orders_router
from database import databaseapp = FastAPI()# 包含来自不同Apps的路由
app.include_router(users_router, prefix="/users", tags=["users"])
app.include_router(items_router, prefix="/items", tags=["items"])
app.include_router(orders_router, prefix="/orders", tags=["orders"])@app.on_event("startup")
async def startup():await database.connect()@app.on_event("shutdown")
async def shutdown():await database.disconnect()

9. 启动应用程序

使用uvicorn启动应用程序:

uvicorn main:app --reload
http://www.yayakq.cn/news/844786/

相关文章:

  • 云服务器 做网站西安网站建设xazxcy
  • 郑州专业做微信网站靖江网站
  • 电子商务网站开发主要有哪些百度合伙人答题兼职赚钱
  • 延边企业网站建设网站主页的布局方式
  • 阳江营销型网站建设企业网站seo参考文献
  • 请求做女朋友的网站源码资阳网站网站建设
  • 网站的稳定性海南网站建设多少钱
  • 怎么做网站更新和维护做一套公司网站费用
  • 爱站网综合查询商城站到汤泉池
  • 如何创立自己的网站旅游建设门户网站的方案
  • 简述网站推广方式小广告
  • 盐城做网站网络公司电话?合肥专业制作网站
  • 北京西城网站建设公司设计包装公司
  • 村级网站建设自媒体发稿
  • 人才招聘网站建设方案优化大师电脑版官网
  • 做文艺文创产品的网站泉州网站设计制作
  • 哪些网站是vue做的大连建设工程信息网怎么没有了
  • 做网站点子网站开发公司特点
  • 宁波网络公司做网站品牌型网站制作
  • 三大门户网站是什么腾讯qq官网登录入口
  • 网站开发 报价单网站建设的需求
  • 网页设计做军事网站的感想协会网站模板
  • 网站设计原则济南网站建设 泉诺
  • 网站建设全攻略教务管理系统是应用软件吗
  • 视频教育网站建设软件工程专业考研考什么
  • 怎样做服装厂的企业网站模版php快速开发平台
  • 男女做羞羞事试看网站设计签名免费名字
  • 建网站备案wordpress页面乱码代码
  • 网站建设公司的wordpress新闻404
  • 四川住房与城乡建设厅网站企业形象vi设计包括哪些