一、SQLAlchemy介绍

  SQLAlchemy 是 Python SQL 工具包和对象关系映射器,为应用程序开发人员提供 SQL 的全部功能和灵活性。

  SQLAlchemy支持SQLite、PostgreSQL、Oracle、MySQL、MariaDB、Microsoft SQL Server等多种数据库。

二、SQLAlchemy安装

  

  我安装的版本是:SQLAlchemy==2.0.29。注意SQLAlchemy2.x以上的版本和1.x版本差别还是挺大的,注意版本。

  因为SQLAlchemy不能直接操作数据库,还需要python中的pymysql第三方库,所以还需要安装pymysql

  

  PyMySQL==1.1.0.

三、创建测试数据库

  创建一个用于测试的数据库

  

  其中sqlalchemydb就是测试数据库

四、封装SQLAlchemyDB类

  在python项目根目录下创建一个sqlalchemy_db.py文件,当然你也可以在其他目录下创建。其中内容如下:

  

  说明1:该文件sqlalchemy_db.py的作用是封装一个SQLAlchemy的类,为实例化sqlAlchemy对象做准备

  说明2:self.engine是连接数据的引擎设置,只有设置了engine,我们才能通过sqlalchemy对象操作数据库

  说明3:self.session可以理解为数据库的操作对象,我们对数据库的操作都是基于该session实现的。

  说明4:engine参数解释

  1. 参数url:SQLAlchemy要连接的数据库地址,其格式为:数据库类型+数据库驱动://数据库用户:数据库密码@数据库地址:端口号/数据库名称?编码方式
  2. 参数convert_unicode:按照指定的编码方式对字符串进行编码解码
  3. 参数isolation_level:设置事务的隔离界别
  4. 参数pool_recycle:设置回收链接的时间,单位毫秒
  5. 参数pool_pre_ping:每次连接前预先ping一下
  6. 参数pool_size: 链接池中保持数据库连接的数量,默认是5
  7. 参数max_overflow :当链接池中的连接数不够用的时候,允许额外再创建的最大链接数量,默认是10
  8. pool_timeout:排队等数据库链接时的超时时间
  说明5: scoped_session创建的session是线程安全的。

五、创建model模型

  5.1 SQLAlchemy支持的数据类型

    • Integer:整形
    • String:字符串
    • Float:浮点型
    • DECIMAL:定点型
    • Boolean:bool
    • Date:日期类型
    • DateTime:日期+时间类型
    • Time:时间类型
    • Enum:枚举类型
    • Text:文本类型
    • LongText:长文本类型

  5.2 SQLAlchemy字段常用的约束

    • default:默认值
    • nullable:是否可空
    • primary_key:是否为主键
    • unique:是否唯一
    • autoincrement:是否自动增长
    • name:该属性在数据库中的映射字段

  5.3 创建测试的model.py文件

    在项目的根目录或者你需要的地方创建一个model.py文件,内容如下:

    

    说明1:为了测试效果,我们在这个model类中尽可能的多展示了不同字段的使用

    说明2:Base.metadata.create_all() 会将我们的模型自动映射到数据库中,当然也可以手动去数据库中创建表

    说明3:我们写好的这个model类暂时还没有使用呢 。

六、创建测试文件

  在项目根目录下或者你需要的地方创建一个test.py文件,内容如下:

  

  这时我们在test.py中就只引入mysql_db和TestModel,其他的先不写,然后使用python test.py运行该脚本,就会发现我们的model模型,已经同步到数据库中了

  

七、添加测试数据

  7.1 单条添加数据

    修改test.py文件如下,然后python test.py执行

    

    执行之后,我们去数据库查看结果如下:

    

    说明1:create_time,update_time,is_delete都是有默认值的字段,如果不设置,会自动显示默认值。

    说明2:money字段总长度时9位,但是可以少于9位,不能多于9位,小数部位不足时补0

  7.2 批量添加数据

    再来演示一下批量增加数据,代码如下还是在test.py中

    

    执行后的结果如下:

    

八、修改删除

  8.1 修改

    刚才已经演示了增加数据的代码,下面我们看一下修改,代码如下,还是在test.py文件中

    

    查看一下数据库

    

  8.2 删除

    可以看到姓名和性别已经修改成功。再来测试一下删除数据

    

    

    可以看出,数据库中已经没有id=1的数据了

九、查询

  在进行查询测试之前,先往数据库中添加一下测试数据

  

  9.1 query关键字

    在做查询的时候我们通常query关键字,它类似于SQL中select 关键字,query参数通常可以填写三类参数

    • model模型对象:指定查找这个模型中所有的字段
    • model模型对象中的属性:可以指定只查找某个model中的几个属性字段
    • 聚合函数:func.count(统计行的数量),func.avg(求平均数),func.max(求最大值),func.min(求最小值),func.sum(求和)

    

    查看一下打印结果

    

    说明1:在做查询的时候 .first() 表示查询第一个满足条件的数据

    说明2:在做查询的时候 .all() 表示查询所有数据

    说明3:如果不是查询全部字段,只查询部分字段或者聚合函数的话,结果返回的是一个元组,通过下标取数据即可

  9.2 filter关键字

    过滤是数据提取的一个很重要的功能,以下对一些常用的过滤条件进行解释,并且这些过滤条件都是只能通过filter方法实现,常用的方法有

    • 相等: ==
    • 不相等: !=
    • 模糊查询:like(%xx$)
    • 包含:in_()
    • 不包含:~ in_() 注意 ~不是直接加在in前面的,注意看代码示例
    • 空:==None 或者 is_(None)
    • 不为空: !=None 或者 isnot(None)
    • 并且: and_()或者也可以使用逗号连接多个条件
    • 或者:or_()

    

    打印结果如下:

    

  9.3分页查询

    方式1:使用limit+offset实现

    

    查询结果为:

    

    方式2:使用slice

    

    输出结果为:

    

十、排序

  

  输出结果为:

  

.mac { width: 10px; height: 10px; border-radius: 5px; float: left; margin: 10px 0 0 5px }
.b1 { background: rgba(224, 68, 62, 1); margin-left: 10px }
.b2 { background: rgba(222, 161, 35, 1) }
.b3 { background: rgba(26, 171, 41, 1) }
.warpper { background: rgba(18, 18, 18, 1); border-radius: 5px; width: 500px; margin-left: 27px }
.mac { width: 10px; height: 10px; border-radius: 5px; float: left; margin: 10px 0 0 5px }
.b1 { background: rgba(224, 68, 62, 1); margin-left: 10px }
.b2 { background: rgba(222, 161, 35, 1) }
.b3 { background: rgba(26, 171, 41, 1) }
.warpper { background: rgba(18, 18, 18, 1); border-radius: 5px; width: 500px; margin-left: 27px }
.mac { width: 10px; height: 10px; border-radius: 5px; float: left; margin: 10px 0 0 5px }
.b1 { background: rgba(224, 68, 62, 1); margin-left: 10px }
.b2 { background: rgba(222, 161, 35, 1) }
.b3 { background: rgba(26, 171, 41, 1) }
.warpper { background: rgba(18, 18, 18, 1); border-radius: 5px; width: 700px; margin-left: 27px }
.mac { width: 10px; height: 10px; border-radius: 5px; float: left; margin: 10px 0 0 5px }
.b1 { background: rgba(224, 68, 62, 1); margin-left: 10px }
.b2 { background: rgba(222, 161, 35, 1) }
.b3 { background: rgba(26, 171, 41, 1) }
.warpper { background: rgba(18, 18, 18, 1); border-radius: 5px; width: 720px; margin-left: 27px }
.mac { width: 10px; height: 10px; border-radius: 5px; float: left; margin: 10px 0 0 5px }
.b1 { background: rgba(224, 68, 62, 1); margin-left: 10px }
.b2 { background: rgba(222, 161, 35, 1) }
.b3 { background: rgba(26, 171, 41, 1) }
.warpper { background: rgba(18, 18, 18, 1); border-radius: 5px; width: 720px; margin-left: 27px }
.mac { width: 10px; height: 10px; border-radius: 5px; float: left; margin: 10px 0 0 5px }
.b1 { background: rgba(224, 68, 62, 1); margin-left: 10px }
.b2 { background: rgba(222, 161, 35, 1) }
.b3 { background: rgba(26, 171, 41, 1) }
.warpper { background: rgba(18, 18, 18, 1); border-radius: 5px; width: 720px; margin-left: 27px }
.mac { width: 10px; height: 10px; border-radius: 5px; float: left; margin: 10px 0 0 5px }
.b1 { background: rgba(224, 68, 62, 1); margin-left: 10px }
.b2 { background: rgba(222, 161, 35, 1) }
.b3 { background: rgba(26, 171, 41, 1) }
.warpper { background: rgba(18, 18, 18, 1); border-radius: 5px; width: 720px; margin-left: 27px }
.mac { width: 10px; height: 10px; border-radius: 5px; float: left; margin: 10px 0 0 5px }
.b1 { background: rgba(224, 68, 62, 1); margin-left: 10px }
.b2 { background: rgba(222, 161, 35, 1) }
.b3 { background: rgba(26, 171, 41, 1) }
.warpper { background: rgba(18, 18, 18, 1); border-radius: 5px; width: 720px; margin-left: 27px }
.mac { width: 10px; height: 10px; border-radius: 5px; float: left; margin: 10px 0 0 5px }
.b1 { background: rgba(224, 68, 62, 1); margin-left: 10px }
.b2 { background: rgba(222, 161, 35, 1) }
.b3 { background: rgba(26, 171, 41, 1) }
.warpper { background: rgba(18, 18, 18, 1); border-radius: 5px; width: 720px; margin-left: 27px }
.mac { width: 10px; height: 10px; border-radius: 5px; float: left; margin: 10px 0 0 5px }
.b1 { background: rgba(224, 68, 62, 1); margin-left: 10px }
.b2 { background: rgba(222, 161, 35, 1) }
.b3 { background: rgba(26, 171, 41, 1) }
.warpper { background: rgba(18, 18, 18, 1); border-radius: 5px; width: 720px; margin-left: 27px }
.mac { width: 10px; height: 10px; border-radius: 5px; float: left; margin: 10px 0 0 5px }
.b1 { background: rgba(224, 68, 62, 1); margin-left: 10px }
.b2 { background: rgba(222, 161, 35, 1) }
.b3 { background: rgba(26, 171, 41, 1) }
.warpper { background: rgba(18, 18, 18, 1); border-radius: 5px; width: 720px; margin-left: 27px }
.mac { width: 10px; height: 10px; border-radius: 5px; float: left; margin: 10px 0 0 5px }
.b1 { background: rgba(224, 68, 62, 1); margin-left: 10px }
.b2 { background: rgba(222, 161, 35, 1) }
.b3 { background: rgba(26, 171, 41, 1) }
.warpper { background: rgba(18, 18, 18, 1); border-radius: 5px; width: 720px; margin-left: 27px }
.mac { width: 10px; height: 10px; border-radius: 5px; float: left; margin: 10px 0 0 5px }
.b1 { background: rgba(224, 68, 62, 1); margin-left: 10px }
.b2 { background: rgba(222, 161, 35, 1) }
.b3 { background: rgba(26, 171, 41, 1) }
.warpper { background: rgba(18, 18, 18, 1); border-radius: 5px; width: 720px; margin-left: 27px }
.mac { width: 10px; height: 10px; border-radius: 5px; float: left; margin: 10px 0 0 5px }
.b1 { background: rgba(224, 68, 62, 1); margin-left: 10px }
.b2 { background: rgba(222, 161, 35, 1) }
.b3 { background: rgba(26, 171, 41, 1) }
.warpper { background: rgba(18, 18, 18, 1); border-radius: 5px; width: 720px; margin-left: 27px }
.mac { width: 10px; height: 10px; border-radius: 5px; float: left; margin: 10px 0 0 5px }
.b1 { background: rgba(224, 68, 62, 1); margin-left: 10px }
.b2 { background: rgba(222, 161, 35, 1) }
.b3 { background: rgba(26, 171, 41, 1) }
.warpper { background: rgba(18, 18, 18, 1); border-radius: 5px; width: 720px; margin-left: 27px }
.mac { width: 10px; height: 10px; border-radius: 5px; float: left; margin: 10px 0 0 5px }
.b1 { background: rgba(224, 68, 62, 1); margin-left: 10px }
.b2 { background: rgba(222, 161, 35, 1) }
.b3 { background: rgba(26, 171, 41, 1) }
.warpper { background: rgba(18, 18, 18, 1); border-radius: 5px; width: 720px; margin-left: 27px }
.mac { width: 10px; height: 10px; border-radius: 5px; float: left; margin: 10px 0 0 5px }
.b1 { background: rgba(224, 68, 62, 1); margin-left: 10px }
.b2 { background: rgba(222, 161, 35, 1) }
.b3 { background: rgba(26, 171, 41, 1) }
.warpper { background: rgba(18, 18, 18, 1); border-radius: 5px; width: 720px; margin-left: 27px }
.mac { width: 10px; height: 10px; border-radius: 5px; float: left; margin: 10px 0 0 5px }
.b1 { background: rgba(224, 68, 62, 1); margin-left: 10px }
.b2 { background: rgba(222, 161, 35, 1) }
.b3 { background: rgba(26, 171, 41, 1) }
.warpper { background: rgba(18, 18, 18, 1); border-radius: 5px; width: 720px; margin-left: 27px }

SQLAlchemy详解的更多相关文章

  1. SqlAlchemy使用详解

    python之sqlalchemy创建表的实例详解 通过sqlalchemy创建表需要三要素:引擎,基类,元素 from sqlalchemy import create_engine from sq ...

  2. SQLAlchemy02 /SQLAlchemy对数据的增删改查操作、属性常用数据类型详解

    SQLAlchemy02 /SQLAlchemy对数据的增删改查操作.属性常用数据类型详解 目录 SQLAlchemy02 /SQLAlchemy对数据的增删改查操作.属性常用数据类型详解 1.用se ...

  3. SQLAlchemy(二):SQLAlchemy对数据的增删改查操作、属性常用数据类型详解

    SQLAlchemy02 /SQLAlchemy对数据的增删改查操作.属性常用数据类型详解 目录 SQLAlchemy02 /SQLAlchemy对数据的增删改查操作.属性常用数据类型详解 1.用se ...

  4. flask基础之session原理详解(十)

    前言 flask_session是flask框架实现session功能的一个插件,用来替代flask自带的session实现机制,flask默认的session信息保存在cookie中,不够安全和灵活 ...

  5. OpenStack计费项目Cloudkitty系列详解(一)

    云计算是一种按需付费的服务模式,虽然OpenStack前期在计量方面走了些“弯路”,但现在的ceilometer.gnocchi.aodh.panko项目的稳步并进算是让其峰回路转.然而,目前来看Op ...

  6. celery详解

    目录 Celery详解 1.背景 2.形象比喻 3.celery具体介绍 3.1 Broker 3.2 Backend 4.使用 4.1 celery架构 4.2 安装redis+celery 4.3 ...

  7. Python 定时任务框架 APScheduler 详解

    APScheduler 最近想写个任务调度程序,于是研究了下 Python 中的任务调度工具,比较有名的是:Celery,RQ,APScheduler. Celery:非常强大的分布式任务调度框架 R ...

  8. PyJWT 详解

    1.首先,我们需要先了解 JWT 的概念,所以我们先看pyjwt的官网 https://jwt.io/ 2.对于官方 JWT 有两篇博文写的不错分别如下: https://blog.csdn.net/ ...

  9. 13-flask博客项目之restful api详解2-使用

    13-flask博客项目之restful api详解1-概念 13-flask博客项目之restful api详解1-概念 Flask-RESTful学习网站 英文:https://flask-res ...

  10. Linq之旅:Linq入门详解(Linq to Objects)

    示例代码下载:Linq之旅:Linq入门详解(Linq to Objects) 本博文详细介绍 .NET 3.5 中引入的重要功能:Language Integrated Query(LINQ,语言集 ...

随机推荐

  1. 机器学习策略篇:详解正交化(Orthogonalization)

    正交化 这是一张老式电视图片,有很多旋钮可以用来调整图像的各种性质,所以对于这些旧式电视,可能有一个旋钮用来调图像垂直方向的高度,另外有一个旋钮用来调图像宽度,也许还有一个旋钮用来调梯形角度,还有一个 ...

  2. python Apscheduler持久化

    from pytz import utc from apscheduler.schedulers.background import BackgroundScheduler from apschedu ...

  3. CentOS系统下,配制nginx访问favicon.ico

    sudo vim /etc/nginx/nginx.conf 添加以下配制: # set site faviconlocation /favicon.ico { root html;} 完整配置如下: ...

  4. 【Azure 环境】当本地网络通过ER专线与Azure云上多个虚拟网络打通,如何通过特定的网络策略来限制本地部分网段访问云上虚拟机22端口?

    问题描述 当本地网络通过ER专线与Azure云上多个虚拟网络打通,如何通过特定的网络策略来限制本地部分网段访问云上虚拟机22端口? 问题回答 根据文档调研,在ER线路服务的层面,是无法做网络策略来限制 ...

  5. 17. Class字节码指令解析

    ## 1. 概述 官方文档:https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html Java 字节码对于虚拟机,就好像汇编语言对于 ...

  6. Codeforces Round 169 (Div. 2)C. Little Girl and Maximum Sum(差分、贪心)

    目录 题面 链接 题意 题解 代码 总结 题面 链接 C. Little Girl and Maximum Sum 题意 给q个[l,r]将所有这些区间里面的数相加和最大. 可以进行的操作是任意排列数 ...

  7. spring注解版 图文教程

    注解方式,需要配置contextp空间,@component若无参数,那就是只能类方式加载 注解开发不用set 构造器 注入函数 注解注入属性 管理第三方bean 示例: 数据库的类写在一个文件,文件 ...

  8. settings.json 20201209

    李昱版 { "editor.fontSize": 20, "workbench.iconTheme": "material-icon-theme&qu ...

  9. Pandas导出美化技巧,让你的Excel更出众

    pandas的DataFrame可以通过设置参数使得在jupyter notebook中显示的更加美观,但是,将DataFrame的数据导出excel时,却只能以默认最朴素的方式将数据写入excel. ...

  10. kubectl create 与 kubectl apply的区别

    kubectl apply和kubectl create都是Kubernetes(k8s)中用于创建或更新资源的命令,但它们在使用方式.功能和灵活性上存在一些区别. 声明式与命令式: kubectl ...