当前位置: 首页 > news >正文

SQLAlchemy列参数的使用和query函数的使用

目录

Column常用参数

代码演示

 代码刨析

query函数的使用

基本用法

常见用法示例

查询所有记录

根据条件查询

查询第一条符合条件的记录

查询特定列的值

添加排序规则

使用聚合函数

连接查询 

使用filter_by


Column常用参数

  • primary_key:True设置某个字段为主键。

class User(Base):__tablename__ = 'users'id = Column(Integer, primary_key=True)
  • autoincrement:True设置这个字段为自动增长的。

from sqlalchemy import Column, Integer, Stringclass User(Base):__tablename__ = 'users'id = Column(Integer, primary_key=True, autoincrement=True)username = Column(String(50))
  • default:设置某个字段的默认值。在发表时间这些字段上面经常用。

class User(Base):__tablename__ = 'users'id = Column(Integer, primary_key=True)status = Column(String(20), default='active')
  • nullable:指定某个字段是否为空。默认值是True,就是可以为空。

class User(Base):__tablename__ = 'users'id = Column(Integer, primary_key=True)name = Column(String(50), nullable=False)
  • unique:指定某个字段的值是否唯一。默认是False。

class User(Base):__tablename__ = 'users'id = Column(Integer, primary_key=True)email = Column(String(100), unique=True)
  • onupdate:在数据更新的时候会调用这个参数指定的值或者函数。在第一次插入这条数据的时候,不会用onupdate的值,只会使用default的值。常用于是update_time字段(每次更新数据的时候都要更新该字段值)。

from sqlalchemy import Column, Integer, String, DateTime, funcclass User(Base):__tablename__ = 'users'id = Column(Integer, primary_key=True)username = Column(String(50))last_updated = Column(DateTime, onupdate=func.now())
  • server_default(服务器端默认值):在数据库层面设置默认值,而不是在Python代码层面。

from sqlalchemy import textclass User(Base):__tablename__ = 'users'id = Column(Integer, primary_key=True)created_at = Column(DateTime, server_default=text('CURRENT_TIMESTAMP'))
  • index(索引):指定是否为该列创建索引,以提高检索速度。

class User(Base):__tablename__ = 'users'id = Column(Integer, primary_key=True)username = Column(String(50), index=True)
  • name:指定ORM模型中某个属性映射到表中的字段名。如果不指定,那么会使用这个属性的名字来作为字段名。如果指定了,就会使用指定的这个值作为表字段名。这个参数也可以当作位置参数,在第1个参数来指定。

title = Column(String(50),name='title',nullable=False)
title = Column('my_title',String(50),nullable=False)

代码演示

from datetime import datetimefrom sqlalchemy import Column,Integer,DateTime,Stringfrom db_util import Base,Sessionclass News(Base):__tablename__ = 't_news2'id = Column(Integer,primary_key = True,autoincrement = True)phone = Column(String(11),unique = True)title = Column(String(32),nullable = False)read_count = Column(Integer,default=1)create_time = Column(DateTime,default = datetime.now)update_time = Column(DateTime,default = datetime.now, onupdate =datetime.now ) # 当数据更新后,参数的内容才会更改def create_data():new1 = News(phone='16866666666',title='测试列参数')with Session() as session:session.add(new1)session.commit()def create_data2():# new1 = News(phone='16866666666',title='测试列参数') # 不允许重复# new1 = News(phone='16866666668') # title不能为空# with Session() as session:#   session.add(new1)#   session.commit()with Session() as session:new1 = session.query(News).first()  new1.read_count = 2session.commit()if __name__ == '__main__':# Base.metadata.create_all()# create_data()create_data2()

 代码刨析

  1. id: 主键列,自动递增。
  2. phone: 字符串类型,长度为11,唯一约束。
  3. title: 字符串类型,最大长度为32,不能为空。
  4. read_count: 整数类型,有一个默认值为1。
  5. create_time: 日期时间类型,有一个默认值为当前时间。
  6. update_time: 日期时间类型,有一个默认值为当前时间,并且在更新时会自动更新为新的时间。

这个脚本中还包含了两个函数 create_data()create_data2(),它们用于向数据库中插入数据。

create_data2() 函数中,首先获取了表中的第一个记录,然后将其read_count修改为2,并提交了事务。

请注意,在这个代码中,onupdate=datetime.now 表示在记录更新时,update_time 会被自动更新为当前时间。

query函数的使用

query 函数是 SQLAlchemy 中用于执行数据库查询操作的方法。它通常用于从数据库中检索数据。

基本用法

session.query(ModelClass)

这里的 ModelClass 定义的模型类,它对应了数据库中的表格。query 函数将返回一个查询对象,可以在该对象上继续添加过滤条件、排序规则等,最终执行查询操作以获取符合条件的数据。

常见用法示例

查询所有记录

result = session.query(User).all()

根据条件查询

result = session.query(User).filter(User.name == 'John').all()

查询第一条符合条件的记录

result = session.query(User).filter(User.name == 'John').first()

查询特定列的值

result = session.query(User.name, User.email).all()

添加排序规则

result = session.query(User).order_by(User.name).all()

使用聚合函数

from sqlalchemy import funcresult = session.query(func.count(User.id)).scalar()

连接查询 

result = session.query(User, Address).join(Address, User.id == Address.user_id).all()

使用filter_by

result = session.query(User).filter_by(name='John').all()

相关文章:

SQLAlchemy列参数的使用和query函数的使用

目录 Column常用参数 代码演示 代码刨析 query函数的使用 基本用法 常见用法示例 查询所有记录 根据条件查询 查询第一条符合条件的记录 查询特定列的值 添加排序规则 使用聚合函数 连接查询 使用filter_by Column常用参数 primary_key:True设置某个字…...

产权未转移登记的离婚析产协议不能对抗债权人

债权人代位析产纠纷作为一个新的民事案由,是民事执行阶段中债务人不能到期清偿债务,又怠于分割共同财产或以诉讼方式分割共同财产,而由债权人请求代替债务人向其他共有人提出分割财产以实现债权的诉讼。债权人代位析产,增加了债权…...

python+nodejs+php+springboot+vue 导师双选系统

为了直观显示系统的功能,运用用例图这样的工具显示分析的结果。分析的导师功能如下。导师管理导师选择信息,管理项目,管理项目提交并对学员提交的项目进行指导。 为了直观显示系统的功能,运用用例图这样的工具显示分析的结果。分析…...

paddle2.3-基于联邦学习实现FedAVg算法

目录 1. 联邦学习介绍 2. 实验流程 3. 数据加载 4. 模型构建 5. 数据采样函数 6. 模型训练 1. 联邦学习介绍 联邦学习是一种分布式机器学习方法,中心节点为server(服务器),各分支节点为本地的client(设备&#…...

伺服丝杠系统常用运算功能块

这篇博客主要介绍伺服、丝杠系统常用的运算功能块,其它相关运算可以查看下面文章链接: 信捷PLC脉冲频率、位移、转速相关计算(C语言编程应用)_RXXW_Dor的博客-CSDN博客里工业控制张力控制无处不在,也衍生出很多张力控制专用控制器,磁粉制动器等,本篇博客主要讨论PLC的张力…...

【Vue】模板语法,事件处理器及综合案例、自定义组件、组件通信

一、事件处理器 我们之前事件监听可以使用v-on 指令 1、事件修饰符 在Vue中我们通过由点(.)表示的指令后缀来调用修饰符,比如: .stop:阻止事件冒泡。当事件触发时,该修饰符将停止事件进一步冒泡到父元素。相当于调用了 event.stop…...

从0开始写中国象棋-创建棋盘与棋子

从控制台版本开始 考虑到象棋程序,其实就是数据结构与算法实现。 所以和界面相关的QT部分我们先放一放。 我们从控制台版本开始。这样大家更容易接受,也不影响开发。 后面我们会把控制台嫁接到QT上完成完整的游戏,那时候自然就水到渠成了…...

软件的开发步骤,需求分析,开发环境搭建,接口文档 ---苍穹外卖1

目录 项目总览 开发准备 开发步骤 角色分工 软件环境 项目介绍 产品原型 技术选型 开发环境搭建 前端:默认已有 后端 使用Git版本控制 数据库环境搭建 前后端联调 ​登录功能完善 导入接口文档 使用swagger​ 和yapi的区别 常用注解 项目总览 开发准备 开发步骤…...

Qt扫盲-QSqlQueryModel理论总结

QSqlQueryModel理论总结 一、概述二、使用1. 与 view 视图 绑定2. 分离视图,只存数据 一、概述 QSqlQueryModel是用于执行SQL语句和遍历结果集的高级接口。它构建在较低级的 QSqlQuery之上,可用于向QTableView 等视图类提供数据,也是使用了Q…...

分类预测 | MATLAB实现WOA-CNN-BiGRU-Attention数据分类预测(SE注意力机制)

分类预测 | MATLAB实现WOA-CNN-BiGRU-Attention数据分类预测(SE注意力机制) 目录 分类预测 | MATLAB实现WOA-CNN-BiGRU-Attention数据分类预测(SE注意力机制)分类效果基本描述模型描述程序设计参考资料 分类效果 基本描述 1.MATLA…...

【单调栈】496. 下一个更大元素 I

496. 下一个更大元素 I 解题思路 首先计算nums2的每一个元素的下一个比他大的元素,使用单调栈将上面的结果和nums2中的每一个元素组成映射map针对每一个Nums1的元素 查询map 记录map 的value class Solution {public int[] nextGreaterElement(int[] nums1, int[…...

搭建Vue的开发环境,Edge浏览器安装VUE拓展工具

一、在下载vue.js文件 在vue官网中下载开发版本的vue.js文件--> 安装 — Vue.js (vuejs.org) 二、将vue.js导入到项目中 这时候我们运行项目控制台会抛出两个错误 三、安装拓展工具 这里以Edge浏览器为例,其他浏览器上可在拓展管理商店中下载 进入Edge的拓展…...

14:00面试,14:06就出来了,这问的谁顶得住啊

从小厂出来,没想到在另一家公司又寄了。 到这家公司开始上班,加班是每天必不可少的,看在钱给的比较多的份上,就不太计较了。没想到8月一纸通知,所有人不准加班,加班费不仅没有了,薪资还要降40%,…...

python 探索分形世界|曼德布洛特|np.frompyfunc()

文章目录 分形的重要特征曼德布洛特集合曼德布洛特集合有一个以证明的结论:图像展示np.ogrid[]np.frompyfunc()集合转图像 julia集合 无边的奇迹源自简单规则的无限重复 ---- 分形之父Benoit B.Mandelbrot 分形的重要特征 自相似性无标度性非线性 曼德布洛特集合…...

Android MVVM示例项目

项目地址 GitHub - yaolunwei/Androidbbc at androidx 项目简介 BBC(基础业务组件) 业务组件的基础,所有业务组件必须基于该组件进行开发,提供一站式开发 快速使用 gradle: implementation com.bigoat.android:bbc:0.0.1 约定成俗 以下继承关系…...

迅为龙芯2K1000开发板通过汇编控制GPIO

上一小节,我们使用了 C 语言控制了 gpio,这一小节我们来看一下如何使用汇编来控制 gpio 呢?有的 同学可能会有疑问了,既然我们可以使用 C 语言来控制 gpio,为什么我们还要使用更底层的汇编语言呢, 如果我…...

合合信息、上海大学、华南理工大学发布业内首个古彝文编码“大字典” ,为古文字打造“身份证”

“乌蒙山连着山外山,月光洒向了响水滩。”近期在各大短视频平台爆火的《奢香夫人》你听过吗?奢香夫人是一位彝族“巾帼英雄”,这首同名歌曲早在2009年便已发布,如今突然“翻红”,不仅体现了大众对于少数民族文化高涨的…...

Django — 类视图和中间件

目录 一、类视图1、基于类的结构2、常见的类视图基类3、类视图的优点4、代码案例 二、中间件1、定义2、工作原理3、自带中间件4、中间件开发流程5、自定义中间件6、案例 一、类视图 类视图(Class-Based Views)是 Django 中用于处理 HTTP 请求和生成 HTT…...

VMware安装CentOS Stream 8以及JDK和Docker

一、下载镜像源 地址:https://developer.aliyun.com/mirror/?spma2c6h.25603864.0.0.285b32d48O2G8Y 二、安装配置 配置项 一共有以下这些,其中软件、软件选择 、安装目的地、网络主机名需要讲一下,其他都简单,自行设置即可。 …...

MySQL作业1

目录 一.创建一张表,包含以下所有数据类型 建表:​编辑 二.使用以下六种约束 1.非空约束 2.唯一约束 3.主键约束 4.外键约束 5.检查约束 6.默认值约束 一.创建一张表,包含以下所有数据类型 Text 类型: Number 类型&#…...

EPLAN新手必看:3分钟搞定自定义工具栏,效率翻倍不是梦

EPLAN高效工作指南:从零开始打造你的专属工具栏 第一次打开EPLAN时,满屏的工具栏按钮是不是让你感到手足无措?作为一名电气设计工程师,我完全理解这种感受。记得我刚接触EPLAN时,常常在密密麻麻的图标中迷失方向&…...

终极Android投屏指南:用escrcpy实现电脑无缝控制手机

终极Android投屏指南:用escrcpy实现电脑无缝控制手机 【免费下载链接】escrcpy 优雅而强大的跨平台 Android 设备控制工具,基于 Scrcpy 的 Electron 应用,支持无线连接和多设备管理,让您的电脑成为 Android 的完美伴侣。 项目地址: https://gitcode.co…...

3步构建数字时光机:GetQzonehistory全方位备份QQ空间回忆方案

3步构建数字时光机:GetQzonehistory全方位备份QQ空间回忆方案 【免费下载链接】GetQzonehistory 获取QQ空间发布的历史说说 项目地址: https://gitcode.com/GitHub_Trending/ge/GetQzonehistory 问题解决矩阵:为什么需要数字记忆备份 数字记忆的…...

OpenClaw安全指南:Qwen3-32B-Chat本地化执行边界控制

OpenClaw安全指南:Qwen3-32B-Chat本地化执行边界控制 1. 为什么需要关注OpenClaw的安全边界? 去年冬天的一个深夜,我被一阵急促的键盘敲击声惊醒。走进书房,发现OpenClaw正在自动执行我前一天设置的爬虫任务——这本是正常现象&…...

告别字符串截取!用正则表达式re模块精准提取HTML表格数据的避坑指南

告别字符串截取!用正则表达式re模块精准提取HTML表格数据的避坑指南 在数据抓取的世界里,HTML解析就像一场永无止境的猫鼠游戏。每当开发者费尽心思用字符串截取搞定一个网站,前端工程师稍微调整下标签结构,整个爬虫就崩溃了。这种…...

遥感影像裁剪避坑指南:如何用ENVI5.3的Subset功能精准提取县区数据(含背景值设置技巧)

遥感影像裁剪避坑指南:ENVI5.3 Subset功能深度解析与实战技巧 当你在处理县域尺度的遥感影像分析时,是否遇到过裁剪后图像边缘出现黑边、数据丢失或坐标错位的问题?这些看似简单的操作细节,往往成为影响后续分析精度的关键因素。本…...

从51到STM32:单片机面试官最爱问的10个底层硬件问题(附避坑指南)

从51到STM32:嵌入式工程师必须掌握的10个硬件设计思维跃迁 当一位习惯51单片机开发的工程师首次接触STM32时,往往会陷入寄存器配置的海洋中不知所措。这两种架构之间的差异不仅仅是性能参数的提升,更代表着嵌入式系统设计思维的全面升级。本文…...

RWKV7-1.5B-g1a实操手册:curl命令调用generate接口+参数组合避坑指南

RWKV7-1.5B-g1a实操手册:curl命令调用generate接口参数组合避坑指南 1. 模型简介 rwkv7-1.5B-g1a 是基于RWKV-7架构的多语言文本生成模型,特别适合以下场景: 基础问答文案续写简短总结轻量中文对话 这个1.5B参数的版本在单卡24GB显存的GPU…...

图像标注难题如何破解?LabelImg工具全面解析与实战指南

图像标注难题如何破解?LabelImg工具全面解析与实战指南 【免费下载链接】labelImg LabelImg is now part of the Label Studio community. The popular image annotation tool created by Tzutalin is no longer actively being developed, but you can check out L…...

【Simulink】双矢量调制MPC在并网逆变器中的实现:从理论到仿真

1. 双矢量MPC为什么更适合并网逆变器控制 我第一次接触双矢量模型预测控制(MPC)是在调试一个光伏并网项目时。当时单矢量MPC的电流纹波始终达不到设计要求,直到看到郭磊磊老师那篇经典论文才恍然大悟——原来矢量组合方式才是破局关键。相比传…...