Loading [MathJax]/jax/output/CommonHTML/config.js
社区首页 >问答首页 >表中行的顺序

表中行的顺序
EN

Stack Overflow用户
提问于 2012-02-23 06:55:05
回答 1查看 112关注 0票数 0

我有以下问题:我正在加载一个只有删除和插入的"dif"-table。“更改”由删除和插入决定。

此表没有主键,也没有可排序的字段。我想使用Hibernate加载这个表。(SELECT obj FROM MyDifTable obj WHERE obj.group = groupId)

现在,我对所有值和上面的查询都使用了一个键,并且没有按照与源表中相同的顺序获得行。

我的问题是:

  1. 如何让Hibernate始终返回与表中相同的顺序?
  2. 如何在本例中指定主键?

我知道这是一件设计得很糟糕的事情,我曾试图与设计团队争论,但没有成功。

向你问好,凯

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-02-23 07:11:25

关系数据库是基于集合论的一个分支。信息要么在数据库中(在集合中),要么不存在。秩序不是集合中的概念,只有存在才是集合中的概念。这意味着,如果需要,您必须显式地建模排序。

如果必须保持顺序,则必须添加一个"order“子句来对集合的结果成员进行排序。有时,这种排序是外部的(因此您可以将排序的决定推迟到查询提交时间)。在非常罕见的情况下,重要的是将这种秩序内化为“数据集”。

在奇怪的情况下,您需要内部化的排序,您必须将顺序与集合中的数据一起存储;但是,要强制执行"order“子句(查询编写人员可能省略),您可能还必须放置数据的几个存储过程/视图,以确保查询始终以正确的顺序返回。

将列表存储到数据库时,内部化排序的示例很常见。一个通常将列表项及其索引存储在同一行的列表中。这样,当检索到它时,您可以恢复项目和排序。

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9415404

复制
相关文章
检测表中行记录是否已存在
检查PG表中行记录是否已存在,可通过发起一个select看下是否有行记录返回,但是依赖于如何做到这点,返回的结果可能比较奇怪或者不太高效。
yzsDBA
2021/01/05
1K0
顺序表的定义_顺序表的逻辑顺序和物理顺序
来看一个生活中的例子:周末和朋友一起吃火锅,人非常多,我们需要在等候区等候,这个等候区就与顺序表有非常多的相似之处,借助它去理解顺序表的特点。首先,在等候区有非常多的椅子,这些椅子往往是排成一排连续排放的,中间不会空出很大的空间造成浪费。这就与在顺序表中选取存储单元的方法是一样的,我们会选取一段地址连续的存储单元去存放顺序表。接着工作人员会安排我们在椅子上连续的坐下等候。在存储单元当中去进行数据的存放是一样的,也是依次地存放线性表当中的数据元素,中间也不会空出许多存储单元造成空间的浪费。最后结伴而行的朋友也会坐在相邻的椅子上,这与顺序表的存放是相同的。在逻辑上相邻的两个元素在物理位置上也要保证它相邻,也会把它存放在相邻的存储单元上。在这个例子当中,其实椅子就代表着存储单元,而每一个等候的人就是要存放的数据元素。来总结一下顺序表的特点:
全栈程序员站长
2022/09/20
1.6K0
线性表的顺序存储——顺序表
线性表的顺序存储又称为顺序表, 它是用一组地址连续的存储单元依次存储线性表中的数据元素. 逻辑上相邻的两个数据元素在物理位置上同样相邻.
后端码匠
2021/01/20
8600
线性表的顺序存储——顺序表
顺序表示的线性表——顺序表
一、定义 线性表是由n个类型相同的数据元素组成的有限序列,记为(a1,a2,...,ai-1,ai,ai+1,...,an)。 二、特点 逻辑上相邻的元素,在物理上也相邻。只要确定了第一个元素的起始位置,线性表的任一元素都可以随机存取,因此,线性表的顺序存储结构是一种随机存取的存储结构。 三、存储结构 #define ListSize 100 typedef struct { DataType list[ListSize]; //DataType表示数据类型,list用于存储线性表中的数据元素
Zoctopus
2018/06/04
9630
顺序表
#include<iostream> #include"cstdlib" #include<string> using namespace std; //定义结构体类型 struct SeqList{ int MAXNUM; int n; int *element; }; typedef struct SeqList *PSeqList; //创建空的循序链表 PSeqList createNullList_seq(int m); //判断链表是否为空 int is
热心的社会主义接班人
2018/09/30
4940
顺序表的算法
静默虚空
2018/01/05
9110
线性表之顺序存储-顺序表
顺序表的操作 向有序顺序表插入一个元素 顺序表的冒泡排序 顺序表的删除操作 顺序表中元素的查找 顺序表的逆置 删除顺序表中的相同元素 向顺序表的指定位置插入元素 打印顺序表 顺序表的存储结构 #define maxsize 100 //存储空间的分配量 //定义顺序表数据类型 typedef struct{ int data[maxsize]; int last; //存放表中最后一个元素的下标 }sequenlist; 顺序表的冒泡排序 voi
Cloud-Cloudys
2020/07/07
8370
SQL 如何将表中行列互换
使用PIVOT需要注意的是,必须把其他列中同一学生不同信息列隐藏才可以。 例如:我们把一行一行列出的科目变成一列一列,我们的SubjectChineseName就要隐藏掉,否则Pivot出来的结果是同一个学生一样有四行。 只不过右边多出了四列科目而已。 我这里先CAST是因为需要转换格式,从NVARCHAR转为FLOAT。 如果我想要转换的行列数据不是数字的话,应该用什么? 我们可以通过COUNT得到出现的次数,也可以通过MIN()或者MAX()直接显示内容。
繁华是客
2023/03/03
1K0
顺序表操作
输入格式 第一行输入一个正整数 mm(1 \leq m \leq 1001≤m≤100),代表一共有 mm 个操作。 接下来输入 mm 行,每行首先输入一个整数 tt,分别代表以下操作: t = 1,代表插入操作,输入两个整数 a 和 b(1000≤a,b≤100),表示在 a 的位置上擦入元素 b,如果插入成功输出success,否则输出failed。 t=2,代表删除操作,输入一个整数 a(1000≤a≤100),删除位置 a上的元素,如果删除成功输出success,否则输出failed。 t=3,代表查找操作,输入一个整数 a(1000≤a≤100),查找元素值为 a 的元素,如果查找成功输出success,否则输出failed。 t=4,代表遍历操作,输出当前顺序表的所有元素。 输出格式 对应每个操作,输出结果。对于前三个操作,如果操作成功输出success,否则输出failed;对于第四个操作,从下标为 00 的位置开始输出当前顺序表的所有元素,每两个整数之间一个空格,最后一个整数后面没有空格。
小飞侠xp
2021/04/19
4520
顺序表操作
顺序表合并
/*.已知有两个按元素值递增有序的顺序表A和B,设计一个算法将表A和表B的全部元素归并为一个按元素值非递减有序的顺序表C。 要求: 从键盘输入顺序表A和B的各元素,编程实现上述算法,输出顺序表A、顺序表B和顺序表C 的所有元素值 。*/ //群:970353786 #include #include #include #include #pragma warning(disable:4996) typedef int ElemType; #define MAXSIZE 100 typedef struc
川川菜鸟
2021/10/18
7430
顺序表详解
顺序表中的每个数据元素(存储位置连续)按其顺序有唯一的索引值(下标值)来访问数据元素的内容。
洁洁
2023/10/10
2520
顺序表应用6:有序顺序表查询(SDUT 3330)
Problem Description 顺序表内按照由小到大的次序存放着n个互不相同的整数,任意输入一个整数,判断该整数在顺序表中是否存在。如果在顺序表中存在该整数,输出其在表中的序号;否则输出“No Found!"。 Input  第一行输入整数n (1 <= n <= 100000),表示顺序表的元素个数; 第二行依次输入n个各不相同的有序非负整数,代表表里的元素; 第三行输入整数t (1 <= t <= 100000),代表要查询的次数; 第四行依次输入t个非负整数,代表每次要查询的数值
Lokinli
2023/03/09
3630
Excel 如何将表中行列互换
在工作中,我们发现有时候需要将表中的行列进行互换。之前我们讲了SQL中的操作,那么如果是Excel如何实现呢?
繁华是客
2023/03/03
1.1K0
Excel 如何将表中行列互换
数据结构--线性表顺序存储(顺序表)
线性表中在逻辑结构上相邻的数据元素存储在相邻的物理存储单元中,即通过数据元素物理存储的相邻关系来反映数据元素之间逻辑上的相邻关系。
风骨散人Chiam
2020/10/28
6770
顺序表应用5:有序顺序表归并(SDUT 3329)
Problem Description 已知顺序表A与B是两个有序的顺序表,其中存放的数据元素皆为普通整型,将A与B表归并为C表,要求C表包含了A、B表里所有元素,并且C表仍然保持有序。 Input  输入分为三行: 第一行输入m、n(1<=m,n<=10000)的值,即为表A、B的元素个数; 第二行输入m个有序的整数,即为表A的每一个元素; 第三行输入n个有序的整数,即为表B的每一个元素; Output  输出为一行,即将表A、B合并为表C后,依次输出表C所存放的元素。 Sample
Lokinli
2023/03/09
1880
Java 3:顺序表的操作
顺序表常见操作有插入、删除、查找、修改。 一、插入: 1.插入有头插、尾插、任意位置插入。在插入时要注意下标的取值在顺序表长度范围内。所以最好在插入之前进行扩容操作。 2.在头插时要注意先将原数组的元素从后往前依次向后移动。因为如果从前往后开始移动的话,会造成后一个元素被前一个元素覆盖,而丢失数据且造成重复。arr[i+1]=arr[i],注意此处i的意思是要移动的元素的下标。 3.任意位置插入与头插类似,从后往前(要插入的位置元素下标)依次向后移动,再将数据插入 二.删除 1.删除有头删、尾删、任意位置删除,要注意删除前,原顺序表是否为空的异常情况。 2.头删与头插相反,是从前往后依次向前移动,即后一个元素arr[i+1]覆盖前一个元素arr[i].arr[i]=arr[i+1] 3.不论查找还是删除,在确定循环语句的初始值和条件时都要仔细思考可取范围 三.查找和修改 查找和修改要注意目标位置的下标不能越界 四.扩容 在java语言中,扩容一般扩为原来的1.5倍,是一种习惯的规范,不是死规则。 最后,附上完整代码,包括初始化、插入、删除、查找、修改、扩容、删除顺序表的相同元素。
py3study
2020/01/10
7200
C语言--顺序表的实现
#include<stdio.h> #define list_init_size 100 typedef struct{ int data[list_init_size]; int length; }Seqlist; void creat(Seqlist &L);//建立线性表 void show(Seqlist L);//显示线性表 void insert(Seqlist &L,int position,int e); //插入数据e,位置为position void so
王也518
2022/10/26
1.4K0
顺序线性表
线性表的顺序表示和实现 线性表的顺序表示指的是用一组地址连续的存储单元依次存储线性表的数据元素。 线性表的第一个数据元素a1的存储位置,通常称作线性表的起始位置或基地址。 只要确定了存储线性表的起始位置,线性表中任一数据元素都可随机存取,所以线性表的顺序存储结构是一种随机存取的存储结构。 数组类型有随机存取的特性,因此通常都用数组来描述数据接哦故中的顺序存储结构。由于线性表的长度可变,且所需最大存储空间随问题不同而不同,在C语言中可用动态分配的一维数组,如下描述。 /* 线性表的动态分配顺序存储结构 */
猿人谷
2018/01/17
7600
顺序线性表
java——顺序表的方法实现
顺序表需要有以下几点思考; 顺序表中间/头部的插入删除,时间复杂度为O(N) 增容需要申请新空间,拷贝数据,释放旧空间。会有不小的消耗。 增容一般是呈2倍的增长,势必会有一定的空间浪费。例如当前容量为100,满了以后增容到200,我们再继续插入了5个数据,后面没有数据插入了,那么就浪费了95个数据空间 顺序表的方法实现: import java.util.Arrays; public class MyArrayList{ public int[] array;//有效数组 public
小雨的分享社区
2022/10/26
4180
线性表的顺序存储
线性表的顺序表示:用一组地址连续的存储单元依次存储线性表的数据元素,这种表示也称为线性表的顺序存储结构或顺序映像。通常,称这种存储结构的线性表为顺序表(Sequential List)。
老齐
2023/03/02
1.6K0
线性表的顺序存储

相似问题

MySQL表中行的更改顺序

13

PostgreSQL:执行表中行的顺序

10

表的SQL中行的顺序总和

22

MySQL -如何更改表中行的顺序

30

更改MySQL表中行顺序的最佳方法?

22
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文