sqlalchemy query函数可用参数有哪些?
一、模型名
二、模型对象属性
三、聚合函数

下面就分别为大家讲讲query函数这三种参数的用法。
在讲之前,我已经把数据库连接配置、模型,以及添加数据写好了,代码如下:
from sqlalchemy import create_engine,Column,String,Integer
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm.session import sessionmaker
import random DIALCT = "mysql"
DRIVER = "pymysql"
USERNAME = "root"
PASSWORD = "admin"
HOST = "127.0.0.1"
PORT = ""
DATABASE = "test"
DB_URI = "{}+{}://{}:{}@{}:{}/{}?charset=utf8".format(DIALCT,DRIVER,USERNAME,PASSWORD,HOST,PORT,DATABASE)
engine = create_engine(DB_URI)
Base = declarative_base(engine)
session = sessionmaker(engine)() class Student(Base):
__tablename__ = "student"
id = Column(Integer , primary_key=True , autoincrement=True)
name = Column(String(50))
score = Column(Integer) def __repr__(self):
return "<Student name:%s,score:%s>"%(self.name,self.score) Base.metadata.drop_all()
Base.metadata.create_all() for i in range(6):
# random.randint(0,100) 随机生成一个0-100之间的成绩
student = Student(name = "name%s"%i,score=random.randint(0,100))
session.add(student)
session.commit()
第一种:模型名
语法:query(模型名)
假如我们现在要查找表中所有学生数据,方法如下:
results = session.query(Student).all()
for result in results:
print(result)
运行上述代码,然后就可以看到查找结果了。

第二种:模型对象属性
语法:query(模型名.模型属性)
比如我们现在只想查看表中所有学生的姓名(看到成绩头有点大),代码如下:
results = session.query(Student.name).all()
for result in results:
print(result)
运行上述代码,我们就可以看到所有学生姓名了,结果如下:
第三种:聚合函数
上述表中我已列出所有所有的聚合函数,下马我就一一为大家讲讲。注意:在使用聚合函数前,记得从sqlalchemy导入
from sqlalchemy import create_engine,Column,String,Integer,func
1、func.sum
语法:query(func.sum(模型对象属性))
比如想要知道所有学生成绩之和,那么我们就可以使用func.sum这个聚合函数来实现
results = session.query(func.sum(Student.score)).all()
print(results)
运行代码,结果学生成绩之和就计算好了。

2、func.max
语法:query(func.max(模型对象属性))
如果要查找考试成绩最高的哪个学生,就可以使用func.max这个函数
results = session.query(func.max(Student.score)).all()
print(results)
嗯,查询出来的学生成绩最高分是98分
3、func.min
语法:query(func.min(模型对象属性))
我们知道最高分,然后想知道班上学生成绩波动大小。哪怎么办呢??想知道成绩波动大小,我们是不是还得知道班上成绩最低分,是吧?然后用最大值减去最小值除以二就可以求出学生成绩波动大小了。哪如何找出最小值呢?方法就是使用func.min这个聚合函数。
results = session.query(func.min(Student.score)).all()
print(results)
运行上述代码,我们就可以查找到分数最低的哪个。
4、func.count
语法:query(func.count(模型对象属性))
results = session.query(func.count(Student.score)).all()
print(results)
不出什么意外的话,我们就能得到下面结果(没错吧,总共是6行):
5、func.avg
语法:query(func.avg(模型对象属性))
期末考试考完,学校通常是不是要跟年级进行对比?对比啥?当然是班级考试成绩排名、好坏啦!那么如何对比呢?是不是通过考试成绩平均分,是吧?我说的没错吧?OK,func.avg这个聚合函数就是为解决求平均值而生的。
results = session.query(func.avg(Student.score)).all()
print(results)
运行上述代码,结果如下:
平均分是58.3333,考的有点不太理想啊。
上面就是关于query函数可用参数讲解。文章若有不当之处,欢迎大家指出!
sqlalchemy query函数可用参数有哪些?的更多相关文章
- document.execCommand()函数可用参数解析
隐藏在暗处的方法-execCommand() 关键字: javascript document document.execCommand()方法可用来执行很多我们无法实现的操作. execComman ...
- 三十二:数据库之SQLAlchemy.query函数可查询的数据和聚合函数
准备工作 from sqlalchemy import create_engine, Column, Integer, String, Floatfrom sqlalchemy.ext.declara ...
- 【Flask】query可用参数
### query可用参数:1. 模型对象.指定查找这个模型中所有的对象.2. 模型中的属性.可以指定只查找某个模型的其中几个属性.3. 聚合函数. * func.count:统计行的数量. * fu ...
- 【matlab】设定函数默认参数
C++/java/python系列的语言,函数可以有默认值,通常类似如下的形式: funtion_name (param1, param2=default_value, ...) 到了matlab下发 ...
- (转)Free函数的参数一定要是malloc返回的那个指针
Free函数的参数一定要是malloc返回的那个指针 之前认为只要free的参数在malloc分配的区域之内就可以了, 现在发现不对的.在嵌入式里分配堆都是按照块来的,只要在这个块内系统就能识别, ...
- Install Shield常用函数以及参数
nstall Shield函数库 1 库函数综述InstallShield包含300多个内部库函数,用户可在安装脚本中调用它们来创建程序组,操作文件夹,处理目录,监督安装状态,创建对话框,操作文件及 ...
- C#学习笔记(十):函数和参数
函数 using System; using System.Collections.Generic; using System.Linq; using System.Text; using Syste ...
- Python 4 函数的参数,内置函数,装饰器,生成器,迭代器,
一.函数的参数: 1.位置参数:调用函数时根据函数定义的参数位置来传递参数. 2.关键字参数:用于函数调用,通过“键-值”形式加以指定.可以让函数更加清晰.容易使用,同时也清除了参数的顺序需求. 3. ...
- Python函数式编程(把函数作为参数传入)
map:接受两个参数(函数,Iterable),map将传入的函数依次作用于Iterable的每个元素,并且返回新的Iterable def f(x): return x*x r = map(f,[1 ...
随机推荐
- k8s中flannel:镜像下载不了
重新部署一套K8S集群时,由于K8S需要扁平化的网络,所以当执行下面的 root@master ~]# kubectl apply -f kube-flannel.yml 会开始下载镜像,然后去启动, ...
- select和FD_SET等
转自:http://blog.csdn.net/cstarbl/article/details/7645298 select函数用于在非阻塞中,当一个套接字或一组套接字有信号时通知你,系统提供sele ...
- HDU1176-免费馅饼(DP)
免费馅饼 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submis ...
- 1.zookeeper原理解析-数据存储之Zookeeper内存结构
Zookeeper是怎么存储数据的,什么机制保证集群中数据是一致性,在网络异常,当机以及停电等异常情况下恢复数据的,我们知道数据库给我们提供了这些功能,其实zookeeper也实现了类似数据库的功能. ...
- VC中MessageBox与AfxMessageBox用法与区别
一.MessageBox()用法 1.函数原型 Messagebox函数在Win32 API和MFC里的定义有区别. Win32 API的定义如下: int WINAPI MessageBox( ...
- leetcode 166分数到小数
手动排除特殊情况: 对于一般情况,使用位运算和加减法来计算除法,使用sign记录结果符号:(这部分为leetcode 29题的答案) 使用hashmap来记录循环体出现的开始位置(如果有的话),使用f ...
- 职位-IT:软件设计师
ylbtech-职位-IT:软件设计师 软件设计师是指能根据软件开发项目管理和软件工程的要求,按照系统总体设计规格说明书进行软件设计,编写程序设计规格说明书等相应的文档的实用性人才.还能够组织和指导程 ...
- 【8】ie css hack
1. "\9" IE6/IE7/IE8/IE9/IE10都生效 "\0" IE8/IE9/IE10都生效,是IE8/9/10的hack "\9 ...
- 阶段3 2.Spring_04.Spring的常用注解_2 常用IOC注解按照作用分类
注解配置和xml的配置要实现的功能都是一样的.都是要降低程序间的耦合,只不过配置的形式不一样 打包方式改成jar 加入spring 的依赖 复制之前的代码过来 复制到我们新建的工程里 resurces ...
- 因修改/etc/ssh权限导致的ssh不能连接异常解决方法
因修改/etc/ssh权限导致的ssh不能连接异常解决方法 现象: $ssh XXX@192.168.5.21 出现以下问题 Read from socket failed: Connection r ...