博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
SQLAlchemy ORM高级查询之过滤,排序
阅读量:7079 次
发布时间:2019-06-28

本文共 3063 字,大约阅读时间需要 10 分钟。

order_by,filter的语法。

用久了才会熟悉。

Session = sessionmaker(bind=engine)session = Session()print(session.query(Cookie.cookie_name, Cookie.quantity).first())for cookie in session.query(Cookie).order_by(desc(Cookie.quantity)):    print('{:3} - {}'.format(cookie.quantity, cookie.cookie_name))# query = session.query(Cookie).order_by(Cookie.quantity)[:2]query = session.query(Cookie).order_by(Cookie.quantity).limit(4)print([result.cookie_name for result in query])inv_count = session.query(func.sum(Cookie.quantity)).scalar()print(inv_count)rec_count = session.query(func.count(Cookie.cookie_name)).first()print(rec_count)rec_count = session.query(func.count(Cookie.cookie_name).label('inventory_count')).first()print(rec_count.keys())print(rec_count.inventory_count)record = session.query(Cookie).filter(Cookie.cookie_name == 'chocolate chip').first()print recordrecord = session.query(Cookie).filter_by(cookie_name='chocolate chip').first()print(record)query = session.query(Cookie).filter(Cookie.cookie_name.like('%chocolate%'))for record in query:    print(record.cookie_name)results = session.query(Cookie.cookie_name, 'SKU-' + Cookie.cookie_sku).all()for row in results:    print(row)query = session.query(Cookie.cookie_name, cast((Cookie.quantity * Cookie.unit_cost),                                               Numeric(12, 2)).label('inv_cost'))for result in query:    print('{} - {}'.format(result.cookie_name, result.inv_cost))query = session.query(Cookie).filter(    Cookie.quantity > 23,    Cookie.unit_cost < 0.40    )for result in query:    print(result.cookie_name)query = session.query(Cookie).filter(    or_(        Cookie.quantity.between(10, 50),        Cookie.cookie_name.contains('chip')        )    )for result in query:    print(result.cookie_name)

输出:

('chocolate chip', 12)100 - oatmeal raisin 24 - peanut butter 12 - chocolate chip 12 - chocolate chip 12 - chocolate chip 12 - chocolate chip  1 - dark chocolate chip  1 - molasses  1 - dark chocolate chip  1 - molasses['dark chocolate chip', 'molasses', 'dark chocolate chip', 'molasses']176(10,)['inventory_count']10Cookie(cookie_name='chocolate chip', cookie_recipe_url='http://www.baidu.com/', cookie_sku='CC01', quantity=12, unit_cost=0.50)Cookie(cookie_name='chocolate chip', cookie_recipe_url='http://www.baidu.com/', cookie_sku='CC01', quantity=12, unit_cost=0.50)chocolate chipchocolate chipchocolate chipdark chocolate chipchocolate chipdark chocolate chip('chocolate chip', 'SKU-CC01')('chocolate chip', 'SKU-CC01')('chocolate chip', 'SKU-CC01')('dark chocolate chip', 'SKU-CC02')('molasses', 'SKU-MOL01')('chocolate chip', 'SKU-CC01')('dark chocolate chip', 'SKU-CC02')('molasses', 'SKU-MOL01')('peanut butter', 'SKU-PB01')('oatmeal raisin', 'SKU-EWW01')chocolate chip - 6.00chocolate chip - 6.00chocolate chip - 6.00dark chocolate chip - 0.75molasses - 0.80chocolate chip - 6.00dark chocolate chip - 0.75molasses - 0.80peanut butter - 6.00oatmeal raisin - 100.00peanut butterchocolate chipchocolate chipchocolate chipdark chocolate chipchocolate chipdark chocolate chippeanut butter

 

转载地址:http://fjjml.baihongyu.com/

你可能感兴趣的文章
使用CDN对动态网站内容加速有效果吗
查看>>
iOS -view横向变成竖向
查看>>
关于INTRAWEB ISAPI DLL发布
查看>>
解决ASP.NET MVC4中使用Html.DropDownListFor显示枚举值默认项问题
查看>>
数据挖掘10大算法介绍
查看>>
《程序员的修炼——从优秀到卓越》
查看>>
sql2005 COM+ 目录要求 (警告)
查看>>
恋恋风尘
查看>>
mongodb - collMod
查看>>
学生如何提高专业英文阅读能力--施一公教授
查看>>
回顾2011,展望2012
查看>>
Android实例RSS客户端开发(3)--rss列表并显示在ui上
查看>>
PCI总线原理(四)
查看>>
unity, 设置帧率上限
查看>>
linux watchdog demo hacking
查看>>
两个函数连续性的讨论
查看>>
从头開始写项目Makefile(五):嵌套运行
查看>>
linux包之bash之内置命令ulimit
查看>>
QQ等软件可以联网 网页打不开
查看>>
c++ 使用socket实现C/S端文件的下载传输
查看>>