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)

时间: 2024-07-29 10:23:50

sqlalchemy操作的相关文章

Python之Mysql及SQLAlchemy操作总结

一.Mysql命令总结 1.创建库 create database test1; 2.授权一个用户 grant all privileges on *.* to 'feng'@'%' identified by '[email protected]'; 3.创建表 create table Teacher( teaId int not null, teaname varchar(100), age int, sex enum('M', 'F'), phone int); 4.查询 select

python如何用sqlalchemy操作数据库

工具:mysql  python sqlalchemy ---------------------------------------- 准备工作: 1.安装mysql 如果是window环境请参考 win7安装mysql 如果是linux环境请参考 --稍后补充 2.安装python windows: win7安装python2和python3 linux: linux安装python36 linux python2.6.6以后的版本同样要通过源码包安装,看了下这位博主的这篇文章写的非常详细h

SqlAlchemy操作(二)

SQLALchemy初始化链接数据库 1. 数据库配置. https://www.cnblogs.com/mengbin0546/p/10124560.html 2.  python端操作. 一.  代码: from sqlalchemy.ext.declarative import declarative_base from sqlalchemy import Column, Integer, String from sqlalchemy.orm import sessionmaker fro

第三十九章:sqlalchemy操作

from sqlalchemy.ext.declarative import declarative_basefrom sqlalchemy import Column, Integer, String, ForeignKey, UniqueConstraint, Indexfrom sqlalchemy.orm import sessionmaker, relationshipfrom sqlalchemy import create_engine ### 连接MySQLengine = cr

SQLAlchemy 操作数据库

首先安装 SQLAlchemy sudo pip3.4 install PyMySQL sudo pip3.4 install sqlalchemy 代码: 1 #!/usr/bin/env python 2 # encoding: utf-8 3 """ 4 @author: 侠之大者kamil 5 @file: Sqlalchemy_test1.py 6 @time: 16/4/11 下午10:41 7 """ 8 #from sqlalch

sqlalchemy操作Mysql

SQLAlchemy“采用简单的Python语言,为高效和高性能的数据库访问设计,实现了完整的企业级持久模型”.SQLAlchemy的理念是,SQL数据库的量级和性能重要于对象集合:而对象集合的抽象又重要于表和行.因此,SQLAlchmey采用了类似于Java里Hibernate的数据映射模型,而不是其他ORM框架采用的Active Record模型.不过,Elixir和declarative等可选插件可以让用户使用声明语法. 安装 pip3 install SQLAlchemy pip3 in

使用SQLAlchemy操作MYSQL黑科技之 event

# coding:utf8 from flask import Flask from flask_sqlalchemy import SQLAlchemy app = Flask(__name__) #app.config.from_pyfile('config') db = SQLAlchemy(app) app.config['SECRET_KEY'] = 'what s the s' app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql://root

sqlalchemy操作----外键关联,relationship

... #!_*_coding:utf-8_*_ #__author__:"Alex huang" import sqlalchemy from sqlalchemy import create_engine from sqlalchemy.ext.declarative import declarative_base from sqlalchemy import Column,Integer,String,ForeignKey from sqlalchemy.orm import r

sqlalchemy操作----多表关联

有二张表,一张作者表,一张书表,一个作者写多本书,一本书可以由多个作者写,与是通过新加一张关系表把他们联系起来 #!/usr/bin/env python # -*- coding: utf-8 -*- # author aliex-hrg from sqlalchemy import Table, Column, Integer,String,DATE, ForeignKey from sqlalchemy.orm import relationship from sqlalchemy.ext