V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
miniyao
V2EX  ›  Python

SQLAlchemy 中 query.filter(...)order_by(...).first() 换成 .second() 取第二条记录,最简单的方式是什么?

  •  
  •   miniyao · 2018-11-17 20:24:04 +08:00 · 2171 次点击
    这是一个创建于 1957 天前的主题,其中的信息可能已经有所发展或是发生改变。
    query 取查询到的第一条记录,用.first()返回最简单。

    要是想直接获取排序中返回的第二条记录,用什么方式最简单?
    (我知道可以通过.all(),然后切片的方式,可以。显得查询量重了一点,最好有个什么简捷的方式,一步查出来,返回一条记录最简单)。
    6 条回复    2018-11-19 09:14:05 +08:00
    fangdingjun
        1
    fangdingjun  
       2018-11-17 20:31:07 +08:00 via Android   ❤️ 1
    limit offset
    SingeeKing
        2
    SingeeKing  
       2018-11-17 20:41:45 +08:00   ❤️ 1
    all() 是一个生成器,所以获取第二条并不会重……
    niubee1
        3
    niubee1  
       2018-11-17 20:43:09 +08:00   ❤️ 1
    query.filter(...)order_by(...)[1:2][0]
    sprite0616
        4
    sprite0616  
       2018-11-18 00:22:25 +08:00
    为什么不加个 filter,把第二条变成第一条呢。
    solupro
        5
    solupro  
       2018-11-18 08:56:05 +08:00 via iPhone
    limit 1,1
    vipppppp
        6
    vipppppp  
       2018-11-19 09:14:05 +08:00
    offset(1).limit(1) =>slice(1, 2)
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   3205 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 11:58 · PVG 19:58 · LAX 04:58 · JFK 07:58
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.