FastAPI 学习之路(三十二)创建数据库
2023-03-15 22:52:02 时间
在大型的web开发中,我们肯定会用到数据库操作,那么FastAPI也支持数据库的开发,你可以用 PostgreSQL MySQL SQLite Oracle 等
本文用SQLite为例。我们看下在fastapi是如何操作设计数据库的
#这个安装依赖也可以 pip install sqlalchemy #我在看到有支持异步的,我用的这个,但是这个没有上面的成熟 pip install fastapi-async-sqlalchemy
我们看下如何在项目中使用
SQLALCHEMY_DATABASE_URL = "sqlite:///./test.db" #固定格式 engine = create_engine( SQLALCHEMY_DATABASE_URL, connect_args={"check_same_thread": False} ) #connect_args 这个只有sqlite才用 SessionLocal = sessionmaker(autocommit=False, autoflush=False, bind=engine) #SessionLocal 类的每个实例都是一个数据库会话。 该类本身还不是数据库会话。 # 但是一旦我们创建了 SessionLocal 类的实例,这个实例将是实际的数据库会话。 Base = declarative_base()
我们用Base作为基础的,通过继承来创建每个数据库模型或类。我们看下
class User(Base): __tablename__ = "users" id = Column(Integer, primary_key=True, index=True) email = Column(String, unique=True, index=True) hashed_password = Column(String) is_active = Column(Boolean, default=True) items = relationship("Item", back_populates="owner") class Item(Base): __tablename__ = "items" id = Column(Integer, primary_key=True, index=True) title = Column(String, index=True) description = Column(String, index=True) owner_id = Column(Integer, ForeignKey("users.id")) owner = relationship("User", back_populates="items")
我们去创建了两个类,一个人,一个每一项,然后有对应的关联关系,这个表格怎么同步到数据库呢,其实很简单。
Base.metadata.create_all(bind=engine)
我们去启动下看看,是否可以创建
我们运行后,可以看到我们的数据库创建完毕了。
表结构和我们设计的是一样的,这样我们就完成了创建数据库的操作,我们接下来就是看,如何去操作数据库。
文章首发在公众号,欢迎关注。
相关文章
- 十大面向Windows的免费数据恢复工具
- Windows 7还能升级Windows 11吗?微软披露Windows11升级细节
- 从模型复杂度角度来理解过拟合现象
- 拉格朗日乘数法,一种计算条件极值的方式
- elasticsearch高亮之highlight原理
- elasticsearch查询之大数据集分页查询
- elasticsearch之多索引查询
- 如何使用注解优雅的记录操作日志 | 萌新写开源 01
- elasticsearch支持大table格式数据的搜索
- 解析fiddler返回的部分数据。
- SpringBoot快速配置多数据源(整合MyBatis)
- WebSocket集群分布式改造:实现多人在线聊天室
- MongoDB之TextSearch简介
- 快速搭建Zookeeper和Kafka环境
- 【秒杀系统】秒杀系统实战(四)| 缓存与数据库双写一致性实战
- 【秒杀系统】秒杀系统实战(五)| 如何优雅的完成订单异步处理
- 缓存与数据库双写一致性 深度分析
- MySQL选错索引导致的线上慢查询事故
- MongoDB中的高级查询(二)
- MongoDB新增及查询数据(一)