- TurboGears 教程
- TurboGears - 首页
- TurboGears - 概述
- TurboGears - 环境
- TurboGears - 第一个程序
- TurboGears - 依赖项
- TurboGears - 服务模板
- TurboGears - HTTP 方法
- Genshi 模板语言
- TurboGears - 包含
- TurboGears - JSON 渲染
- TurboGears - URL 层次结构
- TurboGears - Toscawidgets 表单
- TurboGears - 验证
- TurboGears - 闪存消息
- TurboGears - Cookie 和会话
- TurboGears - 缓存
- TurboGears - Sqlalchemy
- TurboGears - 创建模型
- TurboGears - CRUD 操作
- TurboGears - 数据网格
- TurboGears - 分页
- TurboGears - 管理员访问
- 授权和认证
- TurboGears - 使用 MongoDB
- TurboGears - 脚手架
- TurboGears - 钩子
- TurboGears - 编写扩展
- TurboGears - 可插拔应用程序
- TurboGears - RESTful 应用程序
- TurboGears - 部署
- TurboGears 有用资源
- TurboGears - 快速指南
- TurboGears - 有用资源
- TurboGears - 讨论
TurboGears – SQLAlchemy
虽然可以在 TurboGears 应用程序中使用 SQL 对任何关系数据库执行 CRUD 操作,但建议使用 SQLAlchemy,这是一个强大的 Python 工具包,它是一个强大的对象关系映射器,为应用程序开发人员提供了 SQL 的全部功能和灵活性。除了通过 SQLAlchemy 支持基于 SQL 的数据库之外,TurboGears 还通过 Ming 支持 MongoDB 数据库。在本节中,将讨论 SQLAlchemy 的功能。
什么是 ORM(对象关系映射)?
大多数编程语言平台都是面向对象的。另一方面,RDBMS 服务器中的数据存储为表。对象关系映射是一种将对象参数映射到底层 RDBMS 表结构的技术。ORM API 提供执行 CRUD 操作的方法,而无需编写原始 SQL 语句。
当使用 gearbox 工具包中的“quickstart”命令创建 TurboGears 项目时,默认情况下通过以下配置设置启用 SQLAlchemy 支持:
config['use_sqlalchemy'] = True config['sqlalchemy.url'] = 'sqlite:///devdata.db'
“quickstarted”项目还在其中创建了一个 models 包。例如,“Hello”项目将拥有 Hello\hello\model。在此包中创建以下文件:
__init__.py - 这是设置数据库访问的地方。应用程序的模型对象在此模块中导入。它还具有一个 DBSession - 一个全局会话管理器,以及一个 DeclarativeBase,它是所有模型类的基类。
auth.py - 这是定义身份验证堆栈使用的模型的地方。其他数据库模型存储在此包中,作为单独的模块,并添加到 __init__.py 中。
广告