扫描二维码

关注或者微信搜一搜:编程智域 前端至全栈交流与成长

发现1000+提升效率与开发的AI工具和实用程序https://tools.cmdragon.cn/

1. GraphQL类型系统基础

  • 标量类型:FastAPI支持String/Int/Float/Boolean/ID等基础类型
  • 对象类型示例:
# 使用pydantic定义数据模型
from pydantic import BaseModel class UserProfile(BaseModel):
id: int
username: str
age: int = Field(ge=18, description="必须年满18岁")
email: str = Field(pattern=r"^[a-zA-Z0-9_.+-]+@[a-zA-Z0-9-]+\.[a-zA-Z0-9-.]+$")
  • 枚举类型定义方法:
from enum import Enum

class UserStatus(str, Enum):
ACTIVE = "active"
INACTIVE = "inactive"
SUSPENDED = "suspended"

2. Schema定义规范

graph TD
A[Schema根类型] --> B[Query]
A --> C[Mutation]
B --> D{字段}
D --> E[参数]
D --> F[返回类型]

3. 类型系统高级特性

  • 输入类型输出类型分离原则:
# 输入模型(接收客户端数据)
class UserCreate(BaseModel):
username: str
password: str # 输出模型(返回响应数据)
class UserOut(BaseModel):
id: int
username: str
create_time: datetime

4. 与RESTful对比

# RESTful端点示例
@app.get("/users/{user_id}")
def get_user(user_id: int): # ... # GraphQL等效查询
type Query {
getUser(userId: Int!): User
}

5. 完整示例

# 安装依赖:fastapi==0.95.2 strawberry-graphql==0.155.3 pydantic==1.10.7

from fastapi import FastAPI
import strawberry
from strawberry.asgi import GraphQL @strawberry.type
class Product:
id: int
name: str
price: float @strawberry.type
class Query:
@strawberry.field
def get_product(self, id: int) -> Product:
# 实际应从数据库获取
return Product(id=id, name="Sample", price=99.9) schema = strawberry.Schema(query=Query)
app = FastAPI()
app.add_route("/graphql", GraphQL(schema))

课后Quiz

Q1:如何定义返回手机号格式的字段?

A) 使用String类型

B) 使用正则表达式校验

C) 创建自定义标量类型

正确答案:C。可通过定义标量类型实现格式验证:

@strawberry.scalar
class PhoneNumber:
@staticmethod
def serialize(value: str) -> str:
if not re.match(r'^1[3-9]\d{9}$', value):
raise ValueError("Invalid phone number")
return value

报错处理

问题:查询返回"ValueError: Expected 'User' type"

解决方案:

  1. 检查模型继承是否正确
  2. 确认字段类型与数据库类型匹配
  3. 验证数据序列化过程

    预防建议:
  • 使用mypy进行静态类型检查
  • 编写单元测试验证类型转换

余下文章内容请点击跳转至 个人博客页面 或者 扫码关注或者微信搜一搜:编程智域 前端至全栈交流与成长

,阅读完整的文章:GraphQL类型系统如何让FastAPI开发更高效?

往期文章归档:

免费好用的热门在线工具

GraphQL类型系统如何让FastAPI开发更高效?的更多相关文章

  1. 这些小工具让你的Android 开发更高效

    在做Android 开发过程中,会遇到一些小的问题.尽管自己动手也能解决.可是有了一些小工具,解决这些问题就得心应手了,今天就为大家推荐一下Android 开发遇到的小工具,来让你的开发更高效. Vy ...

  2. UML之轻松入门(2)-掌握Junit,让我们的开发更高效

         使用UML不仅能够形象化的表达我们的程序思想,并且能够帮助我们提高程序的质量.一个杂乱无章的程序让维护者望而生畏,其成本也可想而知.在面向程序设计(OOD)中有5条原则是帮助我们设计一个高效 ...

  3. testNG优雅的使用注解让你的测试项目开发更高效!

    testNG大部分是通过xml配置测试类和监听类 但是这种方法就像传统的spring框架一样需要引入大量的xml配置信息,而且在各层之间也需要通过new对象传递.如果testNG能使用注解注入bean ...

  4. “体检医生”黑科技|让AI开发更精准,ModelArts更新模型诊断功能

    摘要:华为云AI开发平台ModelArts黑科技加持AI研发,让模型开发更高效.更简单,降低AI在行业的落地门槛.全面的可视化评估以及智能诊断功能,使得开发者可以直观了解模型各方面性能,从而进行针对性 ...

  5. 微服务平台(Micro Service Platform : MSP)旨在提供一个集开发、测试、运维于一体的开发者专属平台,让开发者能快速构建或使用微服务,让开发更简单,让运维更高效。

    微服务平台(Micro Service Platform : MSP)旨在提供一个集开发.测试.运维于一体的开发者专属平台,让开发者能快速构建或使用微服务,让开发更简单,让运维更高效. MSP采用业界 ...

  6. 如何更高效地定制你的bootstrap

    bootstrap已经作为前端开发必不可少的框架之一,应用bootstrap使得我们对布局.样式的设定变得非常简单.但bootstrap提供的默认样式往往不能满足我们的需求,从而定制化bootstra ...

  7. 如何使代码审查更高效【摘自InfoQ】

      代码审查者在审查代码时有非常多的东西需要关注.一个团队需要明确对于自己的项目哪些点是重要的,并不断在审查中就这些点进行检查. 人工审查代码是十分昂贵的,因此尽可能地使用自动化方式进行审查,如:代码 ...

  8. 云如何让App开发更简单?

    欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 互联网"下半场",移动App开发对于质量.速度的要求更加苛刻.4月初,腾讯云正式上线移动开发平台MobileLine,借 ...

  9. 25个让Java程序员更高效的Eclipse插件

    Eclipse提供了一个可扩展插件的开发系统.这就使得Eclipse在运行系统之上可以实现各种功能.这些插件也不同于其他的应用(插件的功能是最难用代码实现的).拥有合适的Eclipse插件是非常重要的 ...

  10. 让开发更简单 —— Coding Enterprise 发布

    今天,我们很高兴地宣布 Coding Enterprise 发布了 —— Coding Enterprise 是 CODING 专为企业打造的软件开发协作平台,提供了针对中小型企业的公有云版本和针对大 ...

随机推荐

  1. 【docker】4种网络模式

    bridge模式 使用--net=bridge指定,Docker的默认设置,这种模式创建出来的docker容器链接到Dcoker网桥上(docker0网桥或者其它自定义的网桥): 1)创建一对虚拟网卡 ...

  2. QT C++ 实现数据类与 json 的转换

    QT 提供了 QJsonDocument.QJsonObject.QJsonArray.QJsonValue 等类用于 JSON 的解析和转换.QJsonValue 支持的数据类型包括:bool.do ...

  3. 深入解析Tortoise-ORM关系型字段与异步查询

    title: 深入解析Tortoise-ORM关系型字段与异步查询 date: 2025/05/01 00:12:39 updated: 2025/05/01 00:12:39 author: cmd ...

  4. Spring基于注解的IOC配置

    目录 基于注解的IOC配置 1.用于创建对象的注解 2.用于注入数据的 3.用于改变作用范围的 和生命周期相关 基于注解的IOC配置 曾经XML的配置 <bean id="accoun ...

  5. Go-Spring v1.2.0 版本简介

    引言 随着微服务和云原生架构的普及,Go 语言以其高并发.低延迟和简洁语法在后端开发领域迅速崛起.然而,原生 Go 在项目结构.依赖管理.配置热更新等方面相比 Java Spring 生态尚有短板.G ...

  6. 基于Kubernetes可扩展的Selenium 并行自动化测试部署及搭建(3)——基于k8s的selenium grid集群搭建

    本篇主要讲解如何使用k8s搭建selenium grid集群 Selenium Grid集群部署 1.  首先我们将通过 Kubernetes 服务进行通信以到达hub和nodes.Kubernete ...

  7. C++基础——引用和指针篇

    一.指针(Pointer) 定义: 指针是一个变量,用于存储另一个变量的地址. 基本用法: #include <iostream> using namespace std; int mai ...

  8. ASP.NET Core之Razor Page相关

    cshtml一般是这样: @page @model IndexModel @{ ViewData["Title"] = "Home page"; } <d ...

  9. 西湖论剑2025Misc—cscs

    西湖论剑2025cscs详解 Cobalt Strike流量主要是找beacon,主要以两种形式呈现 ·一小段shellcode(几百个字节),通常叫做stager shellcode,这段代码下载整 ...

  10. SharpIco:用纯C#打造零依赖的.ico图标生成器,支持.NET9与AOT编译

    前言 最近一直在完善我今年的两款桌面软件:视频剪辑工具 Clipify 和 AI 文章创作工具 StarBlogPublisher 虽然界面是基本完善了,但图标还是默认的,显得很不专业 于是我打算给这 ...