sqlalchemy操作
Sqlalchemy ORM操作归类
#简单查询
#注意User是一个类对象,user_table是数据库中的表
#session = sessionmaker() #创建了一个自己定义了的 Session类
1. session.query(User).all()
session.query(User).first()#
记录不存在时,first()
会返回 None
session.query(User).one()#用于获取全部元素,假设没有获得结果或者返回了多个结果,则会产生一个 error
session.query(User).count()#计数
session.query(User).scalar()#返回列表和标量
2. session.query(User).limit(2).all()#最多返回两条数据
session.query(User).offset(3).all()#从第4条数据開始
session.query(User).order_by(User.name).all()#排序
session.query(User).order_by('name').all()
session.query(User).order_by(User.name.desc()).all()
session.query(User).order_by('name desc').all()
3. filter/ filter_by过滤
equals:
session.query(User).filter(User.name == 'ed')
not equals:
session.query(User).filter(User.name != 'ed')
LIKE:
session.query(User).filter(User.name.like('%ed%'))
IN:
session.query(User).filter(User.name.in_(['ed', 'wendy', 'jack']))
# 能够和 query 对象协同工作:
session.query(User).filter(User.name.in_(session.query(User.name).filter(User.name.like('%ed%'))))
NOT IN:
session.query(User).filter(~User.name.in_(['ed', 'wendy', 'jack']))
IS NULL:
session.query(User).filter(User.name == None)
IS NOT NULL:
filter(User.name != None)
AND:
from sqlalchemy import and_
session.query(User).filter(and_(User.name == 'ed', User.fullname =='Ed Jones'))
# 或者连续调用 filter()/filter_by()两次
session.query(User).filter(User.name == 'ed').filter(User.fullname== 'Ed Jones')
OR:
from sqlalchemy import or_
session.query(User).filter(or_(User.name == 'ed', User.name =='wendy'))
match:
session.query(User).filter(User.name.match('wendy'))
match 的參数内容由数据库后台指定。
4. 聚合查询
session.query(func.count('*')).select_from(User).scalar()
session.query(func.count('1')).select_from(User).scalar()
session.query(func.count(User.id)).scalar()
session.query(func.count('*')).filter(User.id> 0).scalar() # filter() 中包括 User,因此不须要指定表
session.query(func.count('*')).filter(User.name== 'a').limit(1).scalar() == 1 # 能够用 limit() 限制 count() 的返回数
session.query(func.sum(User.id)).scalar()
session.query(func.now()).scalar()# func 后能够跟随意函数名,仅仅要该数据库支持
session.query(func.current_timestamp()).scalar()
session.query(func.md5(User.name)).filter(User.id== 1).scalar()
5. 很多其它查询操作
#多条件查询
print(session.query(User).filter(and_(User.name.like("user),User.fullname.like("first%"))).all()
---相当于SQL语句--->
select * from user_table where user_table.name like %user anduser_table.fullname like first%
print(session.query(User).filter(or_(User.name.like("user%),User.password!= None)).all()
---相当于SQL语句--->
select * from user_table where user_table.name = user% oruser_table.password != none
#sql过滤
print(session(User).filter("id>:id").params(id=1).all()
---相当于SQL语句--->
select * from user_table where user_table.id > 1
#关联查询
print(session.query(User,Address).filter(User.id ==Address.user_id).all()
---相当于SQL语句--->
select * from user_table,address_table where user_table.id ==address.user_id
print (session.query(User).jion(User.address).all()
---相当于SQL语句--->
********************
print (session.query(User).outerjoin(User.address).all())
*******************
#子查询
stmt = session.query(Address.user_id,func.count('*').label("address_count").groupby(Address.user_id).subquery()
print(session.query(User,stmt.c.address_count).outjion((stmt,User.id ==stmt.c.user_id.order_by(User_id).all()
#exits
print (session.query(User).filter(exists().where(Address.user_id ==User.id)))
print (session.query(User).filter(User.addresses.any()))
其它《增删改》
query.filter(User.id == 1).update({User.name: 'c'})
user = query.get(1)
print user.name
user.name = 'd'
session.flush() # 写数据库,但并不提交
print query.get(1).name
session.delete(user)
session.flush()
print query.get(1)
session.rollback()
print query.get(1).name
query.filter(User.id == 1).delete()
session.commit()
print query.get(1)
sqlalchemy操作的更多相关文章
- flask 操作mysql的两种方式-sqlalchemy操作
flask 操作mysql的两种方式-sqlalchemy操作 二.ORM sqlalchemy操作 #coding=utf-8 # model.py from app import db class ...
- Python3.x:SQLAlchemy操作数据库
Python3.x:SQLAlchemy操作数据库 前言 SQLAlchemy是一个ORM框架(Object Rational Mapping,对象关系映射),它可以帮助我们更加优雅.更加高效的实现数 ...
- Python之Mysql及SQLAlchemy操作总结
一.Mysql命令总结 1.创建库 create database test1; 2.授权一个用户 grant all privileges on *.* to 'feng'@'%' identifi ...
- Python 使用sqlalchemy操作MYSQL
1. 安装sqlalchemy库 SQL操作引擎可能需要pymysql,故要安装如下两个程序 pip install sqlalchemy pip instal pymysql
- 04:sqlalchemy操作数据库
目录: 1.1 ORM介绍(作用:不用原生SQL语句对数据库操作) 1.2 安装sqlalchemy并创建表 1.3 使用sqlalchemy对表基本操作 1.4 一对多外键关联 1.5 sqlalc ...
- SqlAlchemy操作(三)
1.基于SQLALCHEMY建表 from sqlalchemy.ext.declarative import declarative_base from sqlalchemy import Colu ...
- SqlAlchemy操作(一)
博客转载于 http://www.cnblogs.com/haiyan123/p/8270520.html 一. 介绍 SQLAlchemy是一个基于Python实现的ORM框架.该框架建立在 DB ...
- SqlAlchemy操作(二)
SQLALchemy初始化链接数据库 1. 数据库配置. https://www.cnblogs.com/mengbin0546/p/10124560.html 2. python端操作. 一. ...
- python ORM - sqlalchemy 操作使用
python操作数据库 使用 ORM - sqlalchemy,pymsql 安装: pip install pymsq pip install sqlalchemy 一. '''连接数据库''' ...
随机推荐
- 很好用的一个类:TJvAppXMLFileStorage
以前写软件的时候,在处理软件配置信息的时候,总是要写很多重复的代码,把配置信息写到Ini文件当中.昨天到网上查了一下,发现JVCL中提供了一个非常好用的类TJvAppXMLFileStorage,可以 ...
- 在Qt中使用ActiveX控件
Qt的windows商业版本提供了ActiveQt这个framework,使用这个组件我们可以在Qt中使用ActiveX控件,并且也开发基于Qt的ActiveX控件.ActiveQt包含了两个组件QA ...
- Linux网络基础配置
这是看itercast视频的笔记 Linux网络基础配置 以太网连接 在Linux中,以太网接口被命令为:eth0, eth1等, 0,1代表网卡编号 通过lspci命令可以查看网上硬件信息(如果是u ...
- 《c陷阱与缺陷》笔记--移位运算
#include <stdio.h> int main(void){ int a = 2; a >> 32; a >> -1; a << 32; a & ...
- [C#基础] 泛型
为什么泛型? 在泛型中,最重要的应用便是集合类,因此我们模拟一个简单的集合类 对于上述示例,可以有如下应用 从上可看出,自定义的代码太丑陋了,只能用于string类型. 当然我们可以用object作为 ...
- Python的对象和类型
Python使用对象来存储数据,构造任何类型的值都是一个对象. 任何一个对象都有三个特性:身份,类型和值. 身份是对象的唯一标识,可以通过内建函数id()得到,这个值可以认为是该对象的内存地址. Py ...
- [转]PHP 5.2~5.6 对照以及功能具体解释
[分享]PHP 5.2~5.6 对照以及功能具体解释 作者:流水理鱼wwek 来源:http://www.iamle.com/archives/1530.html 截至眼下(2014.2), PHP ...
- 结合使用AngularJS和Django
原地址 好吧,我承认自己很懒,时间又不够用. 翻译的几个文章都是虎头蛇尾,但我保证这次肯定不太监. 关键的单词不翻译,实在觉得翻译成汉语很别扭,括号里是参考翻译. 有问题和建议尽管提出来,我会改进完善 ...
- JavaScript 中的事件类型5(读书笔记思维导图)
Web 浏览器中可能发生的事件有很多类型.如前所述,不同的事件类型具有不同的信息,而“ DOM3级事件”规定了以下几类事件. UI(User Interface,用户界面)事件:当用户与页面上的元素交 ...
- OCP读书笔记(14) - 管理数据库性能
搜集统计信息 1. dbms_stats gather_schema_stats 1)option:有四个选项: a.gather empty:只分析目前还没有搜集过统计信息的表 SQL> co ...