SQLAlchemy 查询语句

以 Python 原生 sqlalchemy 举例:

# 在 ipython 中写入以下代码,创建两个映射类
In [1]: from sqlalchemy import create_engine, Column, Integer, \
   ...:      String, ForeignKey
   ...: from sqlalchemy.ext.declarative import declarative_base
   ...: from sqlalchemy.orm import relationship, sessionmaker, backref
   ...: engine = create_engine('mysql://root@localhost/test?charset=utf8')
   ...: Base = declarative_base(engine)
   ...: session = sessionmaker(engine)()
   ...: 
   ...: class User(Base):
   ...:     __tablename__ = 'user'
   ...:     id = Column(Integer, primary_key=True)
   ...:     name = Column(String(64), unique=True, index=True)
   ...:     def __repr__(self):
   ...:         return '<User: {}>'.format(self.name)
   ...:             
   ...: class Course(Base):
   ...:     __tablename__ = 'course'
   ...:     id = Column(Integer, primary_key=True)
   ...:     name = Column(String(64), unique=True, nullable=False)
   ...:     user_id = Column(Integer, ForeignKey('user.id'))
   ...:     user = relationship('User', backref='course')
   ...:     def __repr__(self):
   ...:         return '<Course: {}>'.format(self.name)
   ...: 

# 创建数据库表,添加测试数据
In [2]: Base.metadata.create_all()
   ...: u1 = User(name='Kobe')
   ...: u2 = User(name='Nash')
   ...: u3 = User(name='James')
   ...: c1 = Course(name='Mysql 基础', user=u1)
   ...: c2 = Course(name='Flask-SQLAlchemy 快速入门', user=u1)
   ...: for i in (u1, u2, u3, c1, c2):
   ...:     session.add(i)
   ...: session.commit()
   ...: 

query 的基本查询语句:

# 查询全部,相当于 SQL 查询语句:select * from user;
In [7]: session.query(User).all()
Out[7]: [<User Kobe>, <User Nash>, <User James>]

# 查询第一个
In [8]: session.query(User).first()
Out[8]: <User Kobe>

# 条件查询
In [9]: session.query(User).filter(User.name=='James').first()
Out[9]: <User James>

# 同上
In [10]: session.query(User).filter_by(name='James').first()
Out[10]: <User James>

# != 反查询,只有 filter 能用,filter_by 不能用
# 同样的,> < >= <= 均可使用,只有 filter 能用
In [20]: session.query(User).filter(User.name!='Kobe').all()
Out[20]: [<User: James>, <User: Nash>]

# 多条件查询,只有 filter_by 能用,filter 的查询见下面
In [11]: session.query(User).filter_by(name='Kobe', id=1).all()
Out[11]: [<User: Kobe>]

# 查询 User 表中全部数据的 name 值
In [12]: session.query(User.name).all()  # 这种查询方法的返回值类似 namedtuple
Out[12]: [('James'), ('Kobe'), ('Nash')]

In [13]: for i in session.query(User.name).all():
    ...:     print(i)
    ...:     
('James',)
('Kobe',)
('Nash',)

In [14]: for i in session.query(User.name).all():
    ...:     print(i.name)
    ...:     
James
Kobe
Nash

like in_ and_ or_ 四个特殊查询方法,也是只有 filter 能用:

# like 模糊查询
# 查询 name 值中带 e 字符的数据
In [25]: session.query(User).filter(User.name.like('%e%')).all()
Out[25]: [<User: James>, <User: Kobe>]

# in_ 查询某个字段的值属于某个列表
In [31]: session.query(User).filter(User.name.in_(['Kobe', 'James'])).all()
Out[31]: [<User: James>, <User: Kobe>]

In [32]: session.query(User).filter(User.name.in_(['Kobe', 'haha'])).all()
Out[32]: [<User: Kobe>]

# and_ 多条件查询,需要引入,而且不如上面 filter_by 的写法简洁
In [34]: from sqlalchemy import and_

In [35]: session.query(User).filter(and_(User.name=='Kobe', User.id==1)).all()
Out[35]: [<User: Kobe>]

# or_ 符合任一条件即可,也是需要引入
In [37]: from sqlalchemy import or_

In [38]: session.query(User).filter(or_(User.name=='Kobe', User.id==2)).all()
Out[38]: [<User: Kobe>, <User: Nash>]

join 方法进行连表查询:

# 查询 name 值为 'Kobe' 的 user 对应的全部 course
In [13]: session.query(Course).join(User).filter(User.name=='Kobe').all()
Out[13]: [<Course: MySQL 基础>, <Course: Flask 快速入门>]

order_by 方法排序,limit 方法限制数量,count 方法统计数量:

# 对 User 表的 name 列进行排序
In [14]: session.query(User).order_by(User.name).all()
Out[14]: [<User: James>, <User: Kobe>, <User: Nash>]

# 降序排序
In [15]: session.query(User).order_by(User.name.desc()).all()
Out[15]: [<User: Nash>, <User: Kobe>, <User: James>]

# 限制数量
In [16]: session.query(User).order_by(User.name.desc()).limit(2).all()
Out[16]: [<User: Nash>, <User: Kobe>]

# 切片也可以
In [17]: session.query(User).order_by(User.name.desc())[1:]
Out[17]: [<User: Kobe>, <User: James>]

# 统计数量,注意这里没有 .all() 了
In [43]: session.query(User).order_by(User.name.desc()).count()
Out[43]: 3

flask_sqlalchemy 查询语句,跟上面的 sqlalchemy 差不多,基本操作如下:

In [18]: User.query.all()
Out[18]: [<User Kobe>, <User Nash>, <User: James>]

In [19]: User.query.first()
Out[19]: <User Kobe>

In [20]: User.query.filter(User.name=='Kobe').first()
Out[20]: <User Kobe>

In [21]: User.query.filter_by(name='Kobe').first()
Out[21]: <User Kobe>

In [22]: User.query.filter_by(name='Kobe', id=1).first()
Out[22]: <User Kobe>

以上是常用的几个查询语句,更多复杂的使用详见 官方文档 ~~

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,406评论 6 503
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,732评论 3 393
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,711评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,380评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,432评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,301评论 1 301
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,145评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,008评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,443评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,649评论 3 334
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,795评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,501评论 5 345
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,119评论 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,731评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,865评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,899评论 2 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,724评论 2 354