我在 Postgre (9.1.9) 中将串联与 order by 相结合时遇到了麻烦。假设,我有一个包含 3 个字段的表格边框:
Table "borders"
Column | Type | Modifiers
---------------+----------------------+-----------
country1 | character varying(4) | not null
country2 | character varying(4) | not null
length | numeric |
前两个字段是国家代码,第三个字段是这些国家之间的边界长度。
主键在前两个字段上定义。
我需要组成一个对整个表具有唯一值的列的选择,此外,该列应按降序选择。为此,我将关键字段与分隔符连接起来,否则两个不同的行可能会给出相同的结果,例如(AB,C 和 A,BC)。
所以我运行以下查询:
select country1||'_'||country2 from borders order by 1;
但是在结果中,我看到排序中省略了“_”字符。结果如下所示:
?column?
----------
A_CH
A_CZ
A_D
AFG_IR
AFG_PK
AFG_TAD
AFG_TJ
AFG_TM
AFG_UZB
A_FL
A_H
A_I
.
.
您可以看到结果被排序,就好像字符串中不存在“_”一样。
如果我使用字母(比如“x”)作为分隔符 - 顺序是正确的。但是我必须使用一些没有出现在 country1 和 country2 字段中的特殊字符,以避免争用。
我应该怎么做,以便在排序过程中考虑到“_”字符。
编辑
事实证明,串联与问题无关。问题是顺序只是忽略了“_”字符。