一、模型名

二、模型对象属性

三、聚合函数

下面就分别为大家讲讲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函数可用参数有哪些?的更多相关文章

  1. document.execCommand()函数可用参数解析

    隐藏在暗处的方法-execCommand() 关键字: javascript document document.execCommand()方法可用来执行很多我们无法实现的操作. execComman ...

  2. 三十二:数据库之SQLAlchemy.query函数可查询的数据和聚合函数

    准备工作 from sqlalchemy import create_engine, Column, Integer, String, Floatfrom sqlalchemy.ext.declara ...

  3. 【Flask】query可用参数

    ### query可用参数:1. 模型对象.指定查找这个模型中所有的对象.2. 模型中的属性.可以指定只查找某个模型的其中几个属性.3. 聚合函数. * func.count:统计行的数量. * fu ...

  4. 【matlab】设定函数默认参数

    C++/java/python系列的语言,函数可以有默认值,通常类似如下的形式: funtion_name (param1, param2=default_value, ...) 到了matlab下发 ...

  5. (转)Free函数的参数一定要是malloc返回的那个指针

    Free函数的参数一定要是malloc返回的那个指针   之前认为只要free的参数在malloc分配的区域之内就可以了, 现在发现不对的.在嵌入式里分配堆都是按照块来的,只要在这个块内系统就能识别, ...

  6. Install Shield常用函数以及参数

    nstall Shield函数库 1  库函数综述InstallShield包含300多个内部库函数,用户可在安装脚本中调用它们来创建程序组,操作文件夹,处理目录,监督安装状态,创建对话框,操作文件及 ...

  7. C#学习笔记(十):函数和参数

    函数 using System; using System.Collections.Generic; using System.Linq; using System.Text; using Syste ...

  8. Python 4 函数的参数,内置函数,装饰器,生成器,迭代器,

    一.函数的参数: 1.位置参数:调用函数时根据函数定义的参数位置来传递参数. 2.关键字参数:用于函数调用,通过“键-值”形式加以指定.可以让函数更加清晰.容易使用,同时也清除了参数的顺序需求. 3. ...

  9. Python函数式编程(把函数作为参数传入)

    map:接受两个参数(函数,Iterable),map将传入的函数依次作用于Iterable的每个元素,并且返回新的Iterable def f(x): return x*x r = map(f,[1 ...

随机推荐

  1. UE4 使用VaRest的最佳实践

    背景介绍: 用Node.js,express,Mongo搭建了一个简单后台,为项目提供REST风格的API服务. 第一个查询是通过Get进行,返回一个json字符串. 在虚幻里使用VaRest来进行访 ...

  2. R_Studio(关联)对dvdtrans.csv数据进行关联规则分析

    dvdtrans.csv数据:该原始数据仅仅包含了两个字段(ID, Item) 用户ID,商品名称(共30条) #导入arules包 #install.packages("arules&qu ...

  3. hive单用户多点模式配置

    简介 单用户多点模式也称远程服务模式,用户非java客户端访问元数据库,在服务端启动MetaStoreServer,客户端利用Thrift协议通过MetaStoreServer访问元数据库. mysq ...

  4. d3.js+svg的树形图

    效果图 数据 { "name":"中国", "children": [ { "name":"浙江" ...

  5. yum安装Docker

    特别提示:本人博客部分有参考网络其他博客,但均是本人亲手编写过并验证通过.如发现博客有错误,请及时提出以免误导其他人,谢谢!欢迎转载,但记得标明文章出处:http://www.cnblogs.com/ ...

  6. 使用asio进行异步下载http

    下面是官方demo, 给人耳目一新的感觉,以前是总是把c++当成有类功能的C,看完这个感觉不用自己造轮子了,还是要跟上时代的步伐 // // async_client.cpp // ~~~~~~~~~ ...

  7. android 播放音乐媒体文件(四)

    mMediaPlayer 播放网络mp31.异步准备使用 mMediaPlayer.prepareAsync(); 2.监听prepareAsync结果使用MediaPlayer.OnPrepared ...

  8. Android Studio安装Unable to access Android SDK add-on list处理方法

    Unable to access Android SDK add-on list. 很多人写的加屏蔽语句,跳过检测,其实是不行的,因为最后还是要下载. 不翻墙的情况下,一般都是修改host文件:C:\ ...

  9. iOS 的 Gif 渲染

    关于gif的展示,有些项目中很少用到,所以有的人对于这方面了解不是很多 下面介绍几种展示gif的方法,希望大家可以用得上,有更好的方法欢迎评论区留言 一,展示本地的gif,使用的SDWebImage里 ...

  10. 浏览器端-W3School-JavaScript-Browser: Navigator 对象

    ylbtech-浏览器端-W3School-JavaScript-Browser: Navigator 对象 1.返回顶部 1. Navigator 对象 Navigator 对象 Navigator ...