tornado的ORM
tornado的ORM
- 安装sqlalchemy和pymysql
- pip install sqlalchemy
- pip install pymysql
- 连接数据库
from sqlalchemy import create_engine config = {
'HOST': '',
'USERNAME': '',
'PASSWORD': '',
'PORT': '',
'DATABASE': '',
'PARAMS': ''
} DB_URL = 'mysql+pymysql://{USERNAME}:{PASSWORD}@{HOST}:{PORT}/{DATABASE}?{PARAMS}' engine = create_engine(DB_URL.format(**config)) if __name__ == '__main__':
conc = engine.connect()
result = conc.execute('select 1')
print(result.fetchone())如果连接成功,则控制台会出现(1,)的结果
- 数据库建模
- 建立base类
from sqlalchemy import create_engine
from sqlalchemy.ext.declarative import declarative_base config = {
'HOST': '',
'USERNAME': '',
'PASSWORD': '',
'PORT': '',
'DATABASE': '',
'PARAMS': ''
} DB_URL = 'mysql+pymysql://{USERNAME}:{PASSWORD}@{HOST}:{PORT}/{DATABASE}?{PARAMS}' engine = create_engine(DB_URL.format(**config)) Base = declarative_base(engine) - 使用base类并建立表格
from settings import Base
from sqlalchemy import Column, Integer, String, DateTime, Boolean
from datetime import datetime class User(Base):
__tablename__ = 'user' # 指定表名
id = Column(Integer, autoincrement=True, primary_key=True)
username = Column(String(20))
password = Column(String(20))
create_time = Column(DateTime, default=datetime.now())
is_login = Column(Boolean, default=False, nullable=False) if __name__ == '__main__':
Base.metadata.create_all() # 创建表格创建的表名必须为该类的__tablename__属性,Colum新建一个字段,然后给Colum传参来进行约束
- Column的常用参数:
- default: 默认值,可以传一个函数体,default的值等于这个函数体执行后返回的值
- nullable:是否可为空
- primary_key:是否为主键
- unique: 是否唯一
- autoincrement: 是否自增长
- onupdate: 更新的时候执行的函数,和default一样,可以传一个函数体
- name: 该属性在数据库中的字段的映射,默认是属性名
- 常用的数据类型
- Integer: 整形
- Float: 浮点类型
- Boolean:布尔
- DECIMAL: 定点类型: DECIMAL第一个参数为整数位的个数,第二位参数为小数位的个数
- Enum:枚举类型: Enum可以借助python3自带的enum包来实现更加简便
- Date: 传递datetime.date()
- DateTime: 传递datetime.datetime()
- Time:传递datetime.time() 进去
- String: 字符串型, 使用时需要制定长度
- Text: 文本类型
- LONGTEXT: 长文本类型
- 建立base类
- 简单的增删改查
- 增
from sqlalchemy import create_engine
from settings import DB_CONFIG
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import sessionmaker DB_URL = 'mysql+pymysql://{USERNAME}:{PASSWORD}@{HOST}:{PORT}/{DATABASE}?{PARAMS}' engine = create_engine(DB_URL.format(**DB_CONFIG)) Base = declarative_base(engine) Session = sessionmaker(engine) session = Session()与上面不同的是,新建了一个Session对象,然后将这个对象实例化,接下来的数据库操作都用到这个实例对象来操作
from config import Base
from sqlalchemy import Column, Integer, String, DateTime, Boolean
from datetime import datetime class User(Base):
__tablename__ = 'user'
id = Column(Integer, primary_key=True, autoincrement=True)
username = Column(String(20))
password = Column(String(20))
create_time = Column(DateTime, default=datetime.now())
is_login = Column(Boolean, default=False, nullable=False)表结构
from wechat import User
from config import session def add():
user = User(username='ivy', password='')
session.add(user)
session.commit() if __name__ == '__main__':
add()添加一条
from wechat import User
from config import session def add(): session.add_all([
User(username='ivy', password=''),
User(username='ivy1', password=''),
User(username='ivy2', password=''),
])
session.commit() if __name__ == '__main__':
add()添加多条
- 查
from wechat import User
from config import session def search():
session.query(User).all() # 查找所有
result = session.query(User).first().username # 查找第一个
result = session.query(User).filter(User.username=='ivy').first().password
print(result) if __name__ == '__main__':
search()
- 改
from wechat import User
from config import session def update():
session.query(User).filter(User.username == 'ivy').update(
{
User.username: 'bob',
User.password: '',
}
)
session.commit() if __name__ == '__main__':
update()更改的数据以字典的键值对的形式传入
- 删
from wechat import User
from config import session def delete():
result = session.query(User).filter(User.username == 'bob').first() session.delete(result)
session.commit() if __name__ == '__main__':
delete()先查询结果,再讲查询的结果删除,如果查询的结果为空,则删除会报错。
- 每个session执行完毕之后都要close()
- 增
tornado的ORM的更多相关文章
- Tornado + Bootstrap 快速搭建自己的web应用
前言 最近用 python tordado 框架, 整了一个模板页面, 用于接入与发布数据的展示, tornado 简单易用, bootstrap 比较流行, 用起来也省事, 配合起来做些小案例非常迅 ...
- tornado 06 数据库—ORM—SQLAlchemy——基本内容及操作
tornado 06 数据库—ORM—SQLAlchemy——基本内容及操作 一. ORM #在服务器后台,数据是要储存在数据库的,但是如果项目在开发和部署的时候,是使用的不同的数据库,该怎么办?是不 ...
- tornado 07 数据库—ORM—SQLAlchemy—查询
tornado 07 数据库—ORM—SQLAlchemy—查询 引言 #上节课使用query从数据库查询到了结果,但是query返回的对象是直接可用的吗 #在query.py内输入一下内容 from ...
- tornado+sqlalchemy+celery,数据库连接消耗在哪里
随着公司业务的发展,网站的日活数也逐渐增多,以前只需要考虑将所需要的功能实现就行了,当日活越来越大的时候,就需要考虑对服务器的资源使用消耗情况有一个清楚的认知. 最近老是发现数据库的连接数如果 ...
- 浅谈tornado项目应用设计
一.预备知识 最近开始尝试做一些tornado商城项目,在开始之前需要引入一些项目设计知识,如接口,抽象方法抽象类,组合,程序设计原则等,个人理解项目的合理设计可增加其灵活性,降低数据之间的耦合性,提 ...
- Tornado实战项目(伪JD商城)
预备知识 在之前tornado商城项目中,在开始之前需要引入一些项目设计知识,如接口,抽象方法抽象类,组合,程序设计原则等,个人理解项目的合理设计可增加其灵活性, 降低数据之间的耦合性,提高稳定性,下 ...
- tornado web高级开发项目之抽屉官网的页面登陆验证、form验证、点赞、评论、文章分页处理、发送邮箱验证码、登陆验证码、注册、发布文章、上传图片
本博文将一步步带领你实现抽屉官网的各种功能:包括登陆.注册.发送邮箱验证码.登陆验证码.页面登陆验证.发布文章.上传图片.form验证.点赞.评论.文章分页处理以及基于tornado的后端和ajax的 ...
- tornado 学习笔记2 Python web主流框架
2.1 Django 官方网址:https://www.djangoproject.com/ 简介:Django is a high-level Python Web framework that e ...
- Tornado sqlalchemy
上篇文章提到了,最近在用 Python 做一个网站.除了 Tornado ,主要还用到了 SQLAlchemy.这篇就是介绍我在使用 SQLAlchemy 的过程中,学到的一些知识. 首先说下,由于最 ...
随机推荐
- 关于SDL的一些坑:找不到WinMain,不显示控制台,添加链接库等
目录: 用CMake构建SDL时报错 Gcc添加链接库 Gcc找不到入口(WinMain) 让SDL启动时不带控制台窗口 用CMake构建SDL时报错 root@ubuntu:~/SDL# cmake ...
- vue练手项目——桌面时钟
用vue实现一个简单的网页桌面时钟,主要包括时钟显示.计时.暂停.重置等几个功能. 效果图如下,页面刚进来的时候是一个时钟,时钟上显示的时.分.秒为当前实际时间,点击计时器按钮后,页面变成一个计时器, ...
- 曹工说Spring Boot源码(23)-- ASM又立功了,Spring原来是这么递归获取注解的元注解的
写在前面的话 相关背景及资源: 曹工说Spring Boot源码(1)-- Bean Definition到底是什么,附spring思维导图分享 曹工说Spring Boot源码(2)-- Bean ...
- search(2)- elasticsearch scala终端:elastic4s
上篇谈到:elasticsearch本身是一个完整的后台系统,对其的操作使用是通过终端api进行的.elasticsearch本身提供了多种编程语言的api,包括java的esjava.而elasti ...
- 网络安全从入门到精通 (第二章-4) 后端基础PHP—简介及基本函数-上
本文内容 什么是PHP PHP的基础语法 运算符 条件分支语句 1,什么是PHP? PHP(超文本预处理器)是一种通用开源语言,(是动态语言中的一种,动态语言还有ASP,ASPX,JSP). PHP语 ...
- 后端程序员不得不会的 Nginx 转发匹配规则
整理了一些Java方面的架构.面试资料(微服务.集群.分布式.中间件等),有需要的小伙伴可以关注公众号[程序员内点事],无套路自行领取 一口气说出 9种 分布式ID生成方式,面试官有点懵了 面试总被问 ...
- 控制游戏/app使用期限/过期,证书有效期,弹出公告支持离线使用/后端控制,支持Swift、Objective-C集成非常简单,永久免费框架
CertCheck.framework (for iOS) 只能运行于真机上,切勿在模拟器上使用 这是一个控制游戏/app使用期限(到设定的时间无法打开app),或发布弹出公告永久免费的框架,可以全版 ...
- 第十周Java实验作业
实验十 泛型程序设计技术 实验时间 2018-11-1 1.实验目的与要求 (1) 理解泛型概念: 泛型:也称参数化类型,就是在定义类,接口和方法时,通过类型参数只是将要处理的类型对象.(如Arra ...
- fastText 训练和使用
2019-09-09 16:33:11 问题描述:fastText是如何进行文本分类的. 问题求解: fastText是一种Facebook AI Research在16年开源的一个文本分类器. 其特 ...
- TCP、UDP服务器模型 在网络程序里面,通常都是一
TCP.UDP服务器模型 在网络程序里面,通常都是一个服务器处理多个客户机,为了出个多个客户机的请求,服务器端的程序有不同的处理方式. 目前最常用的服务器模型: 循环服务器:循环服务器在同一时刻只能响 ...