tornado 07 数据库—ORM—SQLAlchemy—查询

引言

#上节课使用query从数据库查询到了结果,但是query返回的对象是直接可用的吗
#在query.py内输入一下内容

from connect import session
from user_modules import User rs = session.query(User).filter(User.username=='xuchengcheng') #根据返回结果来看,rs是一个query对象,打印出来可以看到转化过后的SQL
# print(rs,type(rs)) print(session.query(User).filter(User.username=='xuchengcheng').all()) #这个返回的是一个list,列表里面是一个类 print(session.query(User).filter(User.username=='xuchengcheng').first()) #这个返回的是一个类的实例化 print(session.query(User)[0]) #索引为0的值,类似于first,但是不等同于,空列表用这个会报错 rs = session.query(User).filter(User.username=='xuchengcheng').all()
# print(rs) 返回的也是一个列表
print(rs[0].username)#列表所以为0的类的实例化,然后用点方法来取出username
print(getattr(rs[0],'username')) #这种方法也可以取出username rs = session.query(User.username).filter(User.username=='xuchengcheng').all()
print(rs) #返回[('xuchengcheng',)],在query里面指定了某个属性值,返回的也就不是一个query对象,而是直接查询User.username的值,所以就返回了包括元组的列表 rs = session.query(User.username).filter(User.username=='xuchengcheng').first()
print(rs) #返回的就是一个元组

二、条件查询

#如何通过不同的条件在SQLAlchemy中实现查询
#过滤函数filter,通俗点讲就是加条件
#filter是一个过滤函数,过滤条件都可以书写在次函数中,不同的条件之间用逗号隔开 session.query(User).filter(User.username=='xuchengcheng').all() #filter_by也是一个过滤函数,但是功能弱一点
session.query(User).filter_by(username='xuchengcheng').all()
#两者区别
#1、filter中需要添加类对象,filter_by不需要
#2、filter_by中只能添加等于的条件,不能添加不等于、大于小于等条件

  快速添加数据

#中间下面download
#1、点击pycharm右边database
#2、点击绿色加号 DataSource--->MySQL
#3、Name自定义 ; Host不变 ;Database(数据库):选择需要操作的数据库 mydb ;User:admin ; Password : 该用户下的密码Root110qwe
#4、test connection 测试连接
#5、apply ----> OK #然后可以通过database里面的schemas里面的mysql快速添加内容了; 记得最后操作完点击绿色 ->DB 保存

  条件查询

#条件查询
rs = session.query(User).filter(User.username=='xuchengcheng') #模糊查询
rs = session.query(User.username).filter(User.username.like('%cheng%')).all() #模糊查询like rs = session.query(User.username).filter(User.username.notlike('%cheng%')).all()#模糊查询notlike #精确查询
rs = session.query(User.username).filter(User.username.is_(None)).all()#精确查询is,需加上 ‘_’ rs = session.query(User.username).filter(User.username.isnot(None)).all() #精确查询isnot #范围查询
rs = session.query(User.username).filter(User.username.in_(['xuchengcheng','zhouzhou'])).all() #范围查找in_ rs = session.query(User.username).filter(User.username.notin_(['xuchengcheng','zhouzhou'])).all()#范围查找notin_ #limit,offset,slice
print(session.query(User.username).limit(3).all()) #从前向后顺序查循前三条
print(session.query(User.username).offset(2).all()) #偏移2个,前面两个数据不看,从第三个数据开始查询
print(session.query(User.username).slice(1,3).all()) #切片,索引1到2的数据
# print(session.query(User.username).filter(User.username=='xuchengcheng').one()) #只能有一个数据,如果有多个xuchengcheng就会报错;可以用来测试是否只有一条 #排序
from sqlalchemy import desc #desc是需要导入的
print(session.query(User.username,User.id).filter(User.username!='xuchengcheng').order_by(User.id).all()) #查询不等于xuchengcheng的username,并且根据id的顺序来排序(通过order_by)
print(session.query(User.username,User.id).filter(User.username!='xuchengcheng').order_by(desc(User.id)).all()) #查询不等于xuchengcheng的username,并且根据id的反序(desc)序来排序
print(session.query(User.username,User.id).filter(User.username!='xuchengcheng').order_by(User.id).limit(2).all()) #限制数量 #函数
from sqlalchemy import func,extract #使用函数需要导入这两个
print(session.query(User.password).group_by(User.password).all()) #分组group_by
print(session.query(User.password,func.count(User.id)).group_by(User.password).all()) #通过func,函数名的方法来使用函数
print(session.query(User.password,func.count(User.id)).group_by(User.password).having(func.count(User.password)>1).all()) #having通常与group_by连用,添加条件 #根据创建时间里面的时间来排序
print(session.query(extract('minute',User.creatime).label('minute'),func.count(User.id)).group_by('minute').all()) #按分钟分组
# extract:从creatime提取出分钟数 label:取别名 group_by:使用别名

三、多表查询

#多表查询
print(session.query(User,UserDetails).filter(UserDetails.id==User.id).all()) #cross join 查询方法
print(session.query(User.username,UserDetails.lost_login).join(UserDetails,UserDetails.id==User.id).filter(UserDetails.id==User.id).all()) #inner join 查询方法
#在mysql里面这两种方法没有区别
print(session.query(UserDetails.lost_login,User.username).outerjoin(User,User.id==UserDetails.id).filter(UserDetails.id==User.id).all()) #outer join 查询方法 #union 联合查询
q1 = session.query(User.id)
q2 = session.query(UserDetails.id)
q1.union(q2).all() #联合查询,有去重的功能 #子表查询
sql_0 = session.query(UserDetails.lost_login).subquery() #subquery声明子表
print(session.query(User,sql_0.c.lost_login)) #使用子表查询

四、原生SQL查询

#SQLAlchemy虽然可以不用担心SQL问题,但有些情况看上去比较麻烦,这些时候用原生SQL会genjia更加方便
#原生SQL查询
sql_1 = """
select * from `user` #这里需要用反引号
"""
row = session.execute(sql_1)
print(row)
print(row.fetchone()) #得到一条
print(row.fetchmany()) #得到一个列表,里面只有一条
print(row.fetchall()) #得到所有
for i in row: #得到所有
print(i)

tornado 07 数据库—ORM—SQLAlchemy—查询的更多相关文章

  1. tornado 06 数据库—ORM—SQLAlchemy——基本内容及操作

    tornado 06 数据库—ORM—SQLAlchemy——基本内容及操作 一. ORM #在服务器后台,数据是要储存在数据库的,但是如果项目在开发和部署的时候,是使用的不同的数据库,该怎么办?是不 ...

  2. 第二百八十九节,MySQL数据库-ORM之sqlalchemy模块操作数据库

    MySQL数据库-ORM之sqlalchemy模块操作数据库 sqlalchemy第三方模块 sqlalchemysqlalchemy是Python编程语言下的一款ORM框架,该框架建立在数据库API ...

  3. 【tips】ORM - SQLAlchemy操作MySQL数据库

    优先(官方文档SQLAlchemy-version1.2): sqlalchemy | 作者:斯芬克斯 推荐一(长篇幅version1.2.0b3):python约会之ORM-sqlalchemy | ...

  4. 07 模型层 orm相关查询 F查询Q查询 django开启事务

    一.Django终端打印SQL语句 如果你想知道你对数据库进行操作时,Django内部到底是怎么执行它的sql语句时可以加下面的配置来查看 在Django项目的settings.py文件中,在最后复制 ...

  5. python ORM - sqlalchemy 操作使用

    python操作数据库 使用 ORM - sqlalchemy,pymsql 安装: pip install pymsq pip install sqlalchemy 一. '''连接数据库'''   ...

  6. Django学习笔记〇四——数据库ORM的使用(有待修改)

    Django框架基本上都是要和数据库结合使用的,我在以前讲过SQLAlchemy框架的使用,Django支持的不是SQLAlchemy,但是也内嵌了ORM框架,可以不需要直接面对数据库编程,而可以通过 ...

  7. SQLAlchemy04 /SQLAlchemy查询高级

    SQLAlchemy04 /SQLAlchemy查询高级 目录 SQLAlchemy04 /SQLAlchemy查询高级 1.排序 2.limit.offset和切片操作 3.懒加载 4.group_ ...

  8. SQLAlchemy(四):SQLAlchemy查询高级

    目录 SQLAlchemy04 /SQLAlchemy查询高级 1.排序 2.limit.offset和切片操作 3.懒加载 4.group_by 5.having 6.join 7.subquery ...

  9. Python实战 :2017国考职业表excel转数据库,再查询生成excel

    最近看2017年国考的职业表,多而杂,不好过滤我想要的信息,特此把它转成Sqlite3数据库,再从数据库里把查询结果导出成excel,方便找职业. (后附上整套代码) 环境:python2.7   x ...

随机推荐

  1. (一)maven的安装

    Maven下载 下载地址:http://maven.apache.org/download.cgi 下载完成后,得到一个压缩包

  2. bootstrap设计网站中添加代码高亮插件

    这款插件的名字叫做google-code-prettify 使用该插件之前的效果: 使用插件之后的效果: 接下来说步骤: (1)下载两个文件 http://codecloud.sinaapp.com/ ...

  3. 18-拍卖叫价(hdu2149 巴什博弈)

    http://acm.hdu.edu.cn/showproblem.php?pid=2149 Public Sale Time Limit: 1000/1000 MS (Java/Others)    ...

  4. 在Ubuntu安装Tomcat7.0及开机自动运行

    在Ubuntu安装Tomcat7.0及开机自动运行 1.安装装Tomcat7.0 一般都是绿色版的,下载一个tomcat7.0解开到指定的目录上即可 然后进入tomcat目录的bin文件夹,执行 su ...

  5. quilljs 一款简单轻量的富文本编辑器(适合移动端)

    quilljs入门使用教程: quill.js是一款强大的现代富文本编辑器插件.该富文本编辑器插件支持所有的现代浏览器.平板电脑和手机.它提供了文本编辑器的所有功能,并为开发者提供大量的配置参数和方法 ...

  6. Linux mii-tool命令

    一.简介 mii-tool 是一个用来查看,管理介质的网络接口的状态的工具. 二.选项 usage: mii-tool [-VvRrwl] [-A media,... | -F media] [int ...

  7. 第九课,ROS仿真1

    ---恢复内容开始--- 1.stage simulator 它是一个轻量级的仿真软件,它的包名称是stage_ros,可以进入看看,其包含地图在子目录world下, 启动之: rosrun stag ...

  8. 手打的table

    突然觉得,如果我不上传源码和写篇博客,对不起花在这个破网页2个小时的时间,完全手打,浏览器调效果. 源码如下: a.html: <!DOCTYPE html PUBLIC "-//W3 ...

  9. [GO]局部变量的特点

    package main import "fmt" func main() { //定义在{}里的变量就是局部变量,只能在{}里起作用 //作用域,变量起作用的范围 //执行到定义 ...

  10. App测试从入门到精通之更新测试

    我们都知道,app在使用一段时间,都会有更新,而且更新会不止一次.在实际测试中,关于更新的测试场景也是我们需要重点关注的,接下来我们就看一下关于App的更新测试有哪些测试点我们需要注意: APP更新测 ...