- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试在 PostgreSQL 9.4.1 中使用 GROUP BY
,但没有像我希望的那样成功。
有several folks在 the web声称这应该有效,但我无法得到相同的结果。我想要的只是一个不区分大小写的 GROUP BY
但每次我添加 LOWER()
它都会提示:
ERROR: column "people.fn" must appear in the GROUP BY clause or be used in an aggregate function
CREATE DATABASE TEST;
CREATE TABLE people (id INTEGER, fn TEXT, ln TEXT); /* ID, firstname, lastname */
INSERT INTO people (id, fn, ln) VALUES(1,'Mike','f');
INSERT INTO people (id, fn, ln) VALUES(2,'adam','b');
INSERT INTO people (id, fn, ln) VALUES(3,'bill','b');
INSERT INTO people (id, fn, ln) VALUES(4,'Bill','r');
INSERT INTO people (id, fn, ln) VALUES(5,'mike','d');
INSERT INTO people (id, fn, ln) VALUES(6,'mike','c');
INSERT INTO people (id, fn, ln) VALUES(7,'Mike','T');
SELECT fn FROM people GROUP BY LOWER(fn); /* will not run */
SELECT fn FROM people GROUP BY fn; /* runs, but not what I want */
这是我得到的:
adam
mike
Mike
bill
Bill
这是我想要的:
Mike
adam
bill
显然,我缺少一些东西。不,我不能在将数据放入数据库时就对其进行清理。我应该阅读什么来理解这一点?
最佳答案
一般来说,如果你想在聚合查询中选择某物,你必须根据这个“某物”进行分组。在您的情况下,您可以通过选择 lower(fn)
获得您想要的结果:
select lower(fn)
from people
group by lower(fn)
幸运的是,PostgreSQL 允许您按别名分组,因此您不必重复 lower(fn)
两次:
select lower(fn) as lfn
from people
group by lfn
正如@okaram 在评论中提到的,如果您不需要表中的任何其他聚合,您最好使用distinct
:
select distinct lower(fn)
from people
关于sql - PostgreSQL GROUP BY LOWER() 不工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29856589/
当我需要拆分一行,并将列表中的所有单词都设为小写时,首选方式是: 1.) list = [] for word in line.split(): word = word
看看这个答案:Case Insensitive Flask-SQLAlchemy Query 为什么使用 SQLAlchemy 的 func.lower(mystring) 而不是 python 的原
我对 Python 中的内置方法感到困惑。例如,什么是 some_string.lower() 和 str.lower(some_string) 它们有何不同? 最佳答案 str是Python中所有字
print("Hello and welcome to your address book this program uses surnames or D.O.B to find people in
在 Python 中,字符串有一个方法 lower(): >>> dir('A') [... 'ljust', 'lower', 'lstrip', ...] 但是,当尝试 '{0.lower()}'
#include #include #include int main(void) { char input[50]; char i; int j = 0; pr
list-style-type: lower-latin 和 list-style-type: lower-alpha 都会生成如下列表: a. item1 b. item2 c. item3 ...
我目前正在学习 python 并在模块中做练习。我之前已经学习过如何删除字符串中的任何大小写字母,这样用户以后使用它会更容易。但似乎当我将“XXX.lower() ”方法应用于我的代码时,它不起作用。
这是代码; names = ('laia') good = ('good', 'great', 'beautiful') name = raw_input ("What's your name?").
这个问题在这里已经有了答案: Why doesn't calling a string method (such as .replace or .strip) modify (mutate) the
我有一个消除所有非字母字符的正则表达式 def genLetters(string): regex = re.compile('[^a-zA-Z]') newString = regex.su
我有一个名为“Earthquake”的类,它有一个字符串形式的位置,以及一些对这个问题不重要的其他部分(我不认为)。我编写了一个函数(filter_by_place),它迭代我传递给它的地震列表,并在
我在将带有变音符号的大写字母转换为小写字母时遇到问题。 print("ÄÖÜAOU".lower()) A、O 和 U 得到正确转换,但 Ä、Ö 和 Ü 保持大写。有什么想法吗? 第一个问题已通过 .
前言 今天我们总结的函数也比较简单,函数的作用的将所给字符串的中的大写字母转换成小写字母,这种操作往往出现在比较操作之前,比如验证码通常都是不区分大小写的,接下来我们一起看一下函数的用法。 内容
题目地址:https://leetcode.com/problems/to-lower-case/description/ 题目描述: Implement function ToLowerCase
这是我的查询 SELECT * FROM `music` where lower(music.name) = "hello" 我怎样才能用django发送这个查询 我试过了,但它没有在查询中添加 lo
我最近使用 ARM 模板将多个资源部署到 Azure 中。在部署存储帐户时,我遇到了一个问题,这是由于 Azure 提出的一些限制,例如 存储帐户名称不应包含大写字母 其最大长度应为 24。 我希望用
我正在尝试使用 jquery 向下滚动到 #lower div,但由于某种原因它不起作用。我做错了什么? $(function() { $('html, body').animate({
假设我有这样的代码: def c = Account.createCriteria() def results = c { between("balance", 500, 1000)
我在 sqlite 查询中遇到以下异常: The expression contains undefined function call lower() 我在 VS2012 中有一个非常简单的 SQL
我是一名优秀的程序员,十分优秀!