四十:数据库之SQLAlchemy实现排序的三种方式

SQLAlchemy实现排序有三种方式
一:order_by:查询的时候使用此方式根据某个字段或模型下的属性进行排序
二:模型定义的时候,指定排序方式
三:一对多的时候,relationship的order_by参数

准备工作

from sqlalchemy import create_engine, Column, Integer, String, Float, Text, ForeignKeyfrom sqlalchemy.ext.declarative import declarative_basefrom sqlalchemy.orm import sessionmaker, relationship, backref

# 数据库信息host = ‘127.0.0.1‘port = ‘3306‘database = ‘db_to_sqlalchemy‘username = ‘root‘password = ‘123456‘

# 数据库类型+连接数据库的插件,这里使用的pymysqlDB_URI = f‘mysql+pymysql://{username}:{password}@{host}:{port}/{database}‘

engine = create_engine(DB_URI)  # 创建引擎Base = declarative_base(engine)  # 使用declarative_base创建基类session = sessionmaker(engine)()

class Article(Base):    __tablename__ = ‘article‘    id = Column(Integer, primary_key=True, autoincrement=True)    title = Column(String(50), nullable=False)    create_time = Column(DateTime, nullable=False, default=datetime.now)

    def __repr__(self):        return f‘title: {self.title}、create_time: {self.create_time}‘

Base.metadata.drop_all()  # 删除所有表Base.metadata.create_all()  # 创建表

article1 = Article(title=‘title1‘)session.add(article1)session.commit()time.sleep(1)article2 = Article(title=‘title2‘)session.add(article2)session.commit()

一:order_by:查询的时候使用此方式根据某个字段或模型下的属性进行排序

默认升序

倒序:desc()

或者使用sqlalchemy.desc

二:模型定义的时候,指定排序方式

升序

倒序

class Article(Base):    __tablename__ = ‘article‘    id = Column(Integer, primary_key=True, autoincrement=True)    title = Column(String(50), nullable=False)    create_time = Column(DateTime, nullable=False, default=datetime.now)

    __mapper_args__ = {        ‘order_by‘: create_time.desc()    }

    def __repr__(self):        return f‘title: {self.title}、create_time: {self.create_time}‘

三:一对多的时候,relationship的order_by参数

class User(Base):    __tablename__ = ‘user‘    id = Column(Integer, primary_key=True, autoincrement=True)    username = Column(String(50), nullable=False)

class Article(Base):    __tablename__ = ‘article‘    id = Column(Integer, primary_key=True, autoincrement=True)    title = Column(String(50), nullable=False)    create_time = Column(DateTime, nullable=False, default=datetime.now)    uid = Column(Integer, ForeignKey(‘user.id‘))    author = relationship(‘User‘, backref=backref(‘article‘, order_by=create_time.desc()))

    # __mapper_args__ = {    #     ‘order_by‘: create_time    # }

    def __repr__(self):        return f‘title: {self.title}、create_time: {self.create_time}‘

升序

若未在backref中指定排序规则,则会找__mapper_args__下的排序规则

原文地址:https://www.cnblogs.com/zhongyehai/p/11827011.html

时间: 2024-08-06 03:08:33

四十:数据库之SQLAlchemy实现排序的三种方式的相关文章

对集合排序的三种方式

对集合排序,可能最先想到的是使用OrderBy方法. class Program { static void Main(string[] args) { IEnumerable<Student> result = GetStudents().OrderBy(r => r.Score); foreach (var item in result) { Console.WriteLine(item.Name + "--" + item.Score); } Console.R

ava对数组元素排序的三种方式

JAVA中在运用数组进行排序功能时,一般有四种方法:快速排序法.冒泡法.选择排序法.插入排序法.快速排序法主要是运用了Arrays中的一个方法Arrays.sort()实现.冒泡法是运用遍历数组进行比较,通过不断的比较将最小值或者最大值一个一个的遍历出来.选择排序法是将数组的第一个数据作为最大或者最小的值,然后通过比较循环,输出有序的数组. package com.study.test; import java.util.Arrays; public class TestArrSort {   

使用DataSet Datatable 更新数据库的三种方式

1:自动生成命令的条件 CommandBuilder 方法a)动态指定 SelectCommand 属性b)利用 CommandBuilder 对象自动生成 DataAdapter 的 DeleteCommand.InsertCommand 和 UpdateCommand.c)为了返回构造 INSERT.UPDATE 和 DELETE .SQL CommandBuilder 必须执行 SelectCommand.即:必须额外经历一次到数据源的行程,这可能会降低性能.这也是自动生成命令的缺点.d)

[PHP]PHP编程操作Mysql数据库的三种方式

当我开始去接触PHP的时候,真切的感受到其所具有的魅力,本着学习的态度和打破固有的语言和模式的想法,开始了PHP之旅,总的来说,走的还是比较顺利,在其中能够看到C,Java,Perl影子,学习曲线不大,但是做好产品仍然有着一条漫漫长路. 多余的话不说了,慢慢感受和领悟,本文主要讲述PHP操作数据库的三种扩展. 如下图是PHP访问数据库的三种扩展方式: 下面举出三种方式访问数据库并查询数据的实例代码: 1.mysql扩展 <?php //1:获取数据库连接 $connection = @ mysq

十五天精通WCF——第一天 三种Binding让你KO80%的业务

原文:十五天精通WCF--第一天 三种Binding让你KO80%的业务 转眼wcf技术已经出现很多年了,也在.net界混的风生水起,同时.net也是一个高度封装的框架,作为在wcf食物链最顶端的我们所能做的任务已经简单的不能再简单了, 再简单的话马路上的大妈也能写wcf了,好了,wcf最基本的概念我们放在后面慢慢分析,下面我们来看看神奇的3个binding如何KO我们实际场景中的80%的业务场景. 一:basicHttpBinding 作为入门第一篇,也就不深入谈谈basic中的信道栈中那些啥

java中内部类的创建四种情况,三种方式,及内部数据访问权限

内部类和外部类的关系,及内部静态类的数据访问权限,声明方式. 第一种,在外部类内部声明使用内部类,内部类的类型为static和非 static类型,内部类数据类型为private,protected,public 类型的访问权限.外部类为非静态声明和权限如下: package com; public class Test1 { //@author 张春蕾 private class Name{ private int i =1; public int s = 2; protected int m

sqlplus连接oracle数据库三种方式

方式一:命令提示符下敲入sqlplus,然后键入用户名和口令,测试查询 方式二:命令提示符下 敲入sqlplus 用户名/口令@数据库实例 方式三:命令提示符下敲入sqlplus /nolog,然后连接数据库connect scott/[email protected] sqlplus连接oracle数据库三种方式

几种排序算法及Java实现排序的几种方式

几种排序算法 下面的例子介绍了4种排序方法: 冒泡排序, 选择排序, 插入排序, 快速排序 1 package date201709.date20170915; 2 3 public class SortUtil { 4 5 private static int quickSortTimes = 1; 6 7 /** 8 * 冒泡排序:<br> 9 * 两层循环,每次循环比较前后两个元素,如果他们的顺序错误就把他们交换过来,一次循环后最终会把最大的数沉到数列的末端<br> 10 *

排序——冒泡排序(三种方法)

冒泡排序的基本思想: 在要排序的一组数中,对当前还未排好序的范围内的全部数,自上而下对相邻的两个数依次进行比较和调整,让较大的数往下沉,较小的往上冒.即:每当两相邻的数比较后发现它们的排序与排序要求相反时,就将它们互换. 关于程序中4中冒泡排序写法的说明: bubble_sort1:基本的冒泡排序的写法. bubble_sort2:基本冒泡排序的不同写法,基本的冒泡排序是每次遍历,每次缩小范围1,这种办法是每次正向和反向遍历,每次缩小范围2,所以两者的比较次数也是一样的. bubble_sort