#-*- encoding: utf-8 -*-
'''
Created on 2014-12-3
@author: cooler
'''
import tornado.ioloop
import tornado.web
# sqlalchemy 使用
from sqlalchemy import create_engine
from sqlalchemy.orm import sessionmaker
from sqlalchemy import Column
from sqlalchemy.types import CHAR, Integer, String
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy import func, or_, not_
BaseModel = declarative_base()
def init_db():
BaseModel.metadata.create_all(engine)
def drop_db():
BaseModel.metadata.drop_all(engine)
class User(BaseModel):
__tablename__ = 'user'
id = Column(Integer, primary_key=True)
name = Column(CHAR(30)) # or Column(String(30))
#-------------------------------------------------------------------------------------
class MainHandler(tornado.web.RequestHandler):
def get(self):
# self.write('<html><body><form action="/" method="post">'
# '<input type="text" name="message">'
# '<input type="submit" value="Submit">'
# '</form></body></html>')
DB_CONNECT_STRING = 'mysql+mysqldb://cooler:cooler@localhost/testsqlalchemy?charset=utf8'
engine = create_engine(DB_CONNECT_STRING, echo=True)
DB_Session = sessionmaker(bind=engine)
session = DB_Session()
# user = User(name='a')
# session.add(user)
# user = User(name='b')
# session.add(user)
# user = User(name='a')
# session.add(user)
# user = User()
# session.add(user)
# session.commit()
query = session.query(User)
#-------------------------------------------
# print query # 显示SQL 语句
# print query.statement # 同上
# for user in query: # 遍历时查询
# print user.name
#---------------------------------------------
# print query.all()
#---------------------------------------------
# print query.first().name # 记录不存在时,first() 会返回 None
# print query.one().name # 不存在,或有多行记录时会抛出异常
# print query.filter(User.id == 2).first().name
# print query.get(2).name # 以主键获取,等效于上句
# print query.filter('id = 2').first().name # 支持字符串
self.write()
application = tornado.web.Application([
(r"/", MainHandler),
],debug=True)
if __name__ == "__main__":
application.listen(8888)
tornado.ioloop.IOLoop.instance().start()
分享到:
相关推荐
**Tornado-SQLAlchemy:深度解析与应用** Tornado-SQLAlchemy 是一个专门为 Python 的 Tornado Web 框架设计的 SQLAlchemy(一个流行的 ORM 工具)集成库。这个库使得在异步环境下使用 SQLAlchemy 变得更加方便,极...
`tornado_sqlalchemy` 是一个将流行的 Python Web 框架 Tornado 与数据库 ORM(对象关系映射)工具 SQLAlchemy 集成的库。这个压缩包 `tornado_sqlalchemy-0.1.1-py3-none-any.whl` 是针对 Python 3 的一个可安装包...
**PyPI 官网下载 | tornado_sqlalchemy-0.2.0-py3-none-any.whl** 这个资源是Python开发者常用的工具,它来自于Python的官方软件仓库——PyPI(Python Package Index)。PyPI是一个存储各种Python包的地方,使得...
Tornado+Sqlalchemy定时任务实现事件提醒
python 3.8; tornado 6.1; SQLAlchemy 1.4.7
最近在centos部署了一套python框架,总结如下。在32位机器上离线方式部署VMware10+Centos6.9+Openssh7.5+MySQL5.1+Python2.7+Tornado+SQLAlchemy,有问题请联系407169441@qq.com
Python-管理后台脚手架是开发者为快速构建企业级后台应用而设计的一种框架。这个脚手架基于Tornado Web框架,Tornado是一个轻量级、高...同时,基于Tornado和SQLAlchemy的组合,保证了系统的性能和数据操作的灵活性。
Tornado支持使用Python的`pymysql`库或其他ORM(对象关系映射)工具如SQLAlchemy进行数据库操作。通过异步I/O模型,Tornado可以高效地处理数据库查询,避免阻塞主线程。 7. **WebSocket支持**:Tornado对WebSocket...
Tornado是一款开源的Python Web框架和异步网络库,它...在实际项目中,Tornado可以与其他Python库如SQLAlchemy(数据库操作)、Django ORM(对象关系映射)或Flask(微型Web框架)结合使用,构建出功能完备的Web应用。
管理后台脚手架实现了RBAC 和一个简单的SQLALCHEMY的Mapper工具基于tornado框架项目资源H
该项目是一个基于 Python、HTML 和 CSS 的 FPage 项目生成器源码,旨在利用 tornado、mako/jinja2 和 sqlalchemy/peewee 框架快速构建项目。该生成器包含 44 个文件,其中 Python 文件 21 个,HTML 文件 15 个,...
8. **数据库连接**:虽然 Tornado 自身不直接处理数据库,但可以与其他数据库库(如 SQLAlchemy 或 Motor)结合使用。数据库连接的初始化和管理通常在主程序文件中完成。 9. **异步操作**:Tornado 的核心特性之一...
7. **数据库集成**:Tornado虽然不包含内置的数据库抽象层,但它可以与各种数据库驱动程序(如SQLAlchemy或MongoDB)配合使用。你需要了解如何配置数据库连接,以及如何在处理程序中执行查询和处理结果。 8. **...
Tornado自身不提供数据库抽象层,但可以与各种ORM(对象关系映射)工具结合使用,如SQLAlchemy或peewee。在项目中,你可以看到一个`models.py`文件,这里定义了数据库模型。通过连接池管理数据库连接,实现数据的增...
- 对于需要大量数据库交互或业务逻辑复杂的场景,Tornado 可能需要结合其他 ORM(如 SQLAlchemy)或者异步数据库访问库(如 Motor for MongoDB)来提高效率。 总结来说,Tornado 框架是 Python 中专注于高性能、...
2. **ORM 模型**: 虽然Tornado自身不包含ORM(对象关系映射)库,但可以与SQLAlchemy或peewee等第三方库结合,实现对数据库的面向对象操作。 3. **事务处理**: 在Tornado 应用中,可以利用异步数据库库提供的事务...
以下是一份详细步骤,涵盖了如何在阿里云的CentOS7服务器上安装Python 3.8.2、Tornado、MySQL以及SQLAlchemy。 首先,确保你已成功连接到阿里云CentOS7服务器。CentOS是Red Hat Enterprise Linux的开源版本,由Red ...
- **数据库连接**:如使用SQLAlchemy进行ORM操作,或使用pymongo等库与MongoDB交互。 - **身份验证**:可以集成如OAuth2、JWT等身份验证机制。 - **日志记录**:Python的logging模块可用于记录应用日志。 - **测试**...