- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
正如我的问题所述,我想知道我们将 WHERE
子句中具有该类型条件的查询类型称为什么,即:
SELECT * FROM mytable
WHERE (col1, col2) < (1, 2);
换句话说:
给我所有 col1
小于 '1' 的记录,或者如果它等于 '1' 那么 col2
必须小于 '2' - 并且没有一个值是 NULL。
我真的很喜欢这种类型的语法,但不知道关于如何引用这种类型的条件的命名约定是什么。它看起来像一个有条件的元组,但我的搜索没有从该名称中得到任何信息。
我的问题源于需要知道这种语法是什么,以便研究如何使用 Criteria API 编写它。使用 Hibernate、JPA2 和 Postgres。
我能够使用 Criteria API 使用 CriteriaBuilder's function() 编写此代码调用:
//Our left expression (date, id)
Expression leftVal = criteriaBuilder.function("ROW", Tuple.class,
from.get("date").as(java.util.Date.class),
from.get("id").as(Long.class));
//Our right expression ex: ('2015-09-15', 32450)
ParameterExpression<Date> dateParam = criteriaBuilder.parameter(Date.class);
ParameterExpression<Long> idParam = criteriaBuilder.parameter(Long.class);
Expression rightVal = criteriaBuilder.function("ROW", Tuple.class, dateParam, idParam)
//build the first predicate using ROW expressions
Predicate predicate = criteriaBuilder.greaterThan(leftVal, rightVal);
//more query building happens
...
//construct final query and add parameters to our param expressions
TypedQuery<MyEntity> typedQuery = em.createQuery(criteriaQuery);
typedQuery.setParameter(dateParam, current.getDate());
typedQuery.setParameter(idParam, current.getId());
current
在这种情况下是我检索的记录,作为我们想要获取记录之前或之后的行。在此示例中,我按照 greaterThan
函数调用的说明进行操作。
最佳答案
常见的短期术语就是“行值”。或者为您演示的操作“行值比较”。该功能自 SQL-92 以来一直在 SQL 标准中(!)。 Postgres 是目前唯一在所有方面都支持它的主要 RDBMS - 特别是还具有最佳索引支持。
特别是表达式 (col1, col2) < (1, 2)
只是 ROW(col1, col2) < ROW(1, 2)
的简写在 Postgres 中。表达式 ROW(col1, col2)
也称为 row constructor - 就像 ARRAY[col1, col2]
是一个 array constructor .
它是更冗长的等效表达式的缩写:
col1 < 1 OR (col1 = 1 AND col2 < 2)
... Postgres 可以在 (col1, col2)
上使用索引或 (col1 DESC, col2 DESC)
为此。
并且明显不同于:(!)
col1 < 1 AND AND col2 < 2
考虑示例:(1,1)
...
这是 Markus Winand 的演讲,详细讨论了分页功能:
"Pagination done the PostgreSQL way" on use-the-index-luke.com .
行值比较从第 20 页开始。我一直提到的支持矩阵在第 45 页。
我绝不隶属于 Markus Winand。
关于 'WHERE (col1, col2) < (val1, val2)' 的 SQL 语法术语,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32981903/
我创建了一个基本的控制台应用程序来进行这样的测试。 short val = 32767; val++; Console.WriteLine(val);
考虑下面的代码,我试图理解三种不同的数据绑定(bind)方法之间的区别。由于我是 Angular4 的新手,我需要弄清楚何时使用什么。例如要分配 ngModel,请使用 [(ngModel)]。要分配
我看到很多人使用各种不同的方法来检查变量是否为空,似乎真的没有达成共识。我听说 if($foo) 与 if(!empty($foo)) 或 if($foo != "")。 这是真的吗? 我知道这是一个
此代码有效: let mut b: Vec = Vec::with_capacity(a.len()); for val in a.iter() { b.push(val); } 此代码不起作
这可能是 bike-shedding ,但也许我遗漏了一些有趣的东西...... 如果一个类初始化一个成员val至 std::numeric_limits::infinity()后来想检查 val 是
我不知道如何以可搜索的方式表达我的问题,所以如果已经得到解答,请原谅我。我对 SQL 命令还不够熟悉,甚至无法为我指明正确的方向。我有一个连接另外两个表的 sqlite 表。示例: ╔═════╦══
这个似乎依赖于 Java 和 Kotlin 之间的交互,首先是一个 Java 类: public class MyJavaClass { private Runnable q; pub
这个问题已经有答案了: What does &= mean? [closed] (5 个回答) 已关闭 5 年前。 基本上试图找到汉明字符串 https://en.wikipedia.org/wiki
我只是创建一个函数,该函数将 JSON.stringify 输入,同时也会检测数字输入上的 NaN,但不想使用 typeof 由于以下原因。输入可以是数字、 bool 值或字符串。仅此而已。 我已经遇
我正在努力构建允许我从起始值过渡到目标最终值的公式,同时使用 Sin 或 Cos 波在指定时间内衰减? 我正在尝试使用 CSS 和 jsfiddle 模仿我在下面的示例中看到的弹跳效果。我制作这个示例
这个问题已经有答案了: Why are we not allowed to have assignment statements in the file scope in C? (2 个回答) Why
我有这个代码 January February 我用它来尝试获取值: $month = $("#month option:selected").val(); 但它返回文本“Janu
在我的 Kotlin 项目中,我想在编译时声明常量: 所以我用这个: @RunWith(AndroidJUnit4::class) class TradersActivityTest { pr
我是 Java 新手,我知道这是一个愚蠢的问题,但我无法理解 Java 初始化变量的方式。我尝试做一些测试,但我不知道这是如何工作的。 当我学习C或Java编程时,定义新变量的语法是这样的: type
我正在尝试在 kotlin 中编写一个函数,但我无法将值重新分配给函数参数,它说 val cannot be reassigned 。 class WebView{ var homepage
我将查询字符串传递到我的 Windows Phone 应用程序中的页面:page.xaml?key=val&key2=val . 我收到的是 NavigationContext.QueryString
我正在阅读 https://github.com/antirez/redis 中的 Redis 源代码. 我在src/ziplist.c中看到了这样的宏 #define INT24_MAX 0x7ff
我想知道下面两种情况有什么区别,推荐使用哪种? $val = 0; if (!$val) { //True } if (empty($val) { //It's also True } 最佳答
我理解在 Kotlin 中 const val 用于声明常量,而 val 用于只读属性。但是,我想知道在以下情况下,哪个更适合使用。 假设我有一个 fragment 需要一个用于 saveInstan
LinkedIn 问题 const val 可以做什么 @JvmField val 不能做什么? 关于 Val 和 const 之间的区别,有多种答案。canst Val 和 @JvmField Va
我是一名优秀的程序员,十分优秀!