2026/5/21 16:33:30
网站建设
项目流程
公司网站公司,中山外发加工网,网站有多少个,天津网站建设公司电扬文章目录一、模块导入二、初始化FastAPI对象三、数据库配置1、定义 SQLite 数据库的连接路径2、创建数据库连接3、创建会话四、创建数据库模型1、创建一个基础类2、定义数据库模型五、创建数据库表六、创建用户模型七、设置接口实例一、模块导入
from fastapi import FastAPI,…文章目录一、模块导入二、初始化FastAPI对象三、数据库配置1、定义 SQLite 数据库的连接路径2、创建数据库连接3、创建会话四、创建数据库模型1、创建一个基础类2、定义数据库模型五、创建数据库表六、创建用户模型七、设置接口实例一、模块导入fromfastapiimportFastAPI,HTTPExceptionfrompydanticimportBaseModelfromsqlalchemyimportcreate_engine,Column,Integer,Stringfromsqlalchemy.ormimportsessionmaker,declarative_base二、初始化FastAPI对象appFastAPI()三、数据库配置1、定义 SQLite 数据库的连接路径database_urlsqlite:///./text2.dbsqlite:///代表使用sqlite数据库后面的 ./text2.db 代表该数据库的相对路径2、创建数据库连接enginecreate_engine(database_url,connect_args{check_same_thread:False})第一个参数为要创建的数据库的地址第二个参数为check_same_thread: 设置为 False 时允许在不同线程间共享数据库连接对于具体区别可以看作添加该参数允许跨线程使用数据库连接不添加该参数需要确保每个线程都有独立的数据库连接否则就会报错3、创建会话SessionLocalsessionmaker(autocommitFalse,autoflushFalse,bindengine)这里的参数一是关闭自动提交参数二为关闭自动刷新参数三为指定要操作的数据库连接这里是创建了一个数据库会话工厂 SessionLocal用于生成数据库会话对象也就是对数据库的操作对象四、创建数据库模型1、创建一个基础类Basedeclarative_base()declarative_base(): 这是 SQLAlchemy 提供的一个工厂函数用于创建一个基类这个基类是使用声明式语法定义数据库表模型的基础2、定义数据库模型classLogin(Base):# 表名__tablename__loginidColumn(Integer,primary_keyTrue,indexTrue)usernameColumn(String,uniqueTrue,indexTrue)passwordColumn(String)classUser(Base):# 表名__tablename__useridColumn(Integer,primary_keyTrue,indexTrue)nameColumn(String)ageColumn(Integer)addressColumn(String)numberphoneColumn(String)五、创建数据库表Base.metadata.create_all(bindengine)如果bindengin的数据库连接对应的数据库表不存在则创建六、创建用户模型classUserCreate(BaseModel):name:strage:int|NoneNoneaddress:str|NoneNonenumberphone:str|NoneNone小技巧除一定会传入的参数外其他参数可以使用设空值的方法来优化后续的传参步骤七、设置接口实例app.get(/login)deflogin(login:LoginCreate):try:sessionSessionLocal()user_dbsession.query(Login).filter(Login.usernamelogin.username,Login.passwordlogin.password).first()ifuser_db:returnf{login.username}登录成功else:return用户名或密码错误exceptExceptionase:returnf登录失败:{e}注意对于SQLALchemy在接口内对数据库进行操作的前提是要创建一个会议对象也就是session SessionLocal()然后通过session来调用函数进行查询和其他的操作