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操作的更多相关文章

  1. flask 操作mysql的两种方式-sqlalchemy操作

    flask 操作mysql的两种方式-sqlalchemy操作 二.ORM sqlalchemy操作 #coding=utf-8 # model.py from app import db class ...

  2. Python3.x:SQLAlchemy操作数据库

    Python3.x:SQLAlchemy操作数据库 前言 SQLAlchemy是一个ORM框架(Object Rational Mapping,对象关系映射),它可以帮助我们更加优雅.更加高效的实现数 ...

  3. Python之Mysql及SQLAlchemy操作总结

    一.Mysql命令总结 1.创建库 create database test1; 2.授权一个用户 grant all privileges on *.* to 'feng'@'%' identifi ...

  4. Python 使用sqlalchemy操作MYSQL

    1. 安装sqlalchemy库 SQL操作引擎可能需要pymysql,故要安装如下两个程序 pip install sqlalchemy pip instal pymysql

  5. 04:sqlalchemy操作数据库

    目录: 1.1 ORM介绍(作用:不用原生SQL语句对数据库操作) 1.2 安装sqlalchemy并创建表 1.3 使用sqlalchemy对表基本操作 1.4 一对多外键关联 1.5 sqlalc ...

  6. SqlAlchemy操作(三)

    1.基于SQLALCHEMY建表 from sqlalchemy.ext.declarative import declarative_base from sqlalchemy import Colu ...

  7. SqlAlchemy操作(一)

    博客转载于 http://www.cnblogs.com/haiyan123/p/8270520.html 一. 介绍 SQLAlchemy是一个基于Python实现的ORM框架.该框架建立在 DB ...

  8. SqlAlchemy操作(二)

    SQLALchemy初始化链接数据库 1. 数据库配置. https://www.cnblogs.com/mengbin0546/p/10124560.html 2.  python端操作. 一.  ...

  9. python ORM - sqlalchemy 操作使用

    python操作数据库 使用 ORM - sqlalchemy,pymsql 安装: pip install pymsq pip install sqlalchemy 一. '''连接数据库'''   ...

随机推荐

  1. 【iOS开发-31】UITabBar背景、icon图标颜色、被选中背景设置以及隐藏UITabBar的两种方式

    一.对UITabBar背景和icon图标的一些设置 (1)由于直接给UITabBar设置的背景颜色显示的不纯.半透明的感觉,所以,有时候我们能够直接利用纯色的图片作为背景达到想要的效果. (2)给ic ...

  2. javascript (九)注释

    单行注释,采用双斜杠  // 多行注释,采用 /* */

  3. javascript创建类的6种方式

    javascript创建类的7种方式 一 使用字面量创建 1.1 示例 var obj={}; 1.2 使用场景 比较适用于临时构建一个对象,且不关注该对象的类型,只用于临时封装一次数据,且不适合代码 ...

  4. CentOS6.4 编译安装Python 3.3.2 - CRPER木木

    基础环境: CentOS6.4(预装GCC,或者联网YUM---GCC编译写进这里太臃肿,找机会另外写一篇) Python 3.3.2     下载链接: http://www.python.org/ ...

  5. [to do list][PCB][questions]and[plan]

    Questions 2014/5/29 1.最后检查布板,除了用netlist查,还有没有更快的方法? 2014/6/8 1.      R的location中心究竟是哪个? watermark/2/ ...

  6. android binder机制之——(创建binder服务)

      Binder机制编程 前面的几篇文章具体介绍了android中binder机制的方方面面,相信你对binder机制已经有了较深刻的理解.俗话说得好"学以致用",以下我们就通过在 ...

  7. C语言实现通用数据结构的高效设计

    近期在阅读一个开源的C++代码.里面用到了大量的STL里面的东西.或许是自己一直用C而非常少用C++来实现算法的原因.STL里面大量的模板令人心烦.一直对STL的效率表示怀疑,但在网上搜到这样一个帖子 ...

  8. LeetCode——Populating Next Right Pointers in Each Node II

    Follow up for problem "Populating Next Right Pointers in Each Node". What if the given tre ...

  9. Spring Framework AOP具体解释

    此前对于AOP的使用仅限于声明式事务,除此之外在实际开发中也没有遇到过与之相关的问题.近期项目中遇到了下面几点需求,细致思考之后,认为採用AOP来解决.一方面是为了以更加灵活的方式来解决这个问题,还有 ...

  10. struts2错误验证

    在登陆的时候一般要用错误验证功能.效果如图: 在action层的写法: this.addActionError("username或password错误"); 在jsp页面上取值: ...