0

我已经搜索了很长时间,但是我找到的解决方案并没有按我的需要工作。

让我解释一下:我有一张包含数千种产品的表格,每个产品都有一个字母数字 SKU,也用于排序。该 SKU 包括:

Category Code(可变数量的字母字符),

Product Number(整数),

Product Model Variation(可选,可变数量的字母字符)

例如:(MANT 12 CL不带空格)


现在,我需要像这样订购它们(如果这些是文件名,OSX Finder 会完美地订购它们):

MANT1
MANT2
MANT2C
MANT2D
MANT2W
MANT3
MANT4C
MANT9
MANT12
MANT12C
MANT12CL
MANT12P
MANT13
MANT21
MANT24
MANT24D
MANT29

当然ORDER BY sku显然是错误的:

MANT1
MANT12
MANT12C
MANT12CL
MANT12P
MANT13
MANT2
MANT21
MANT24
MANT24D
MANT29
MANT2C
MANT2D
MANT2W
MANT3
MANT4C
MANT9

并且ORDER BY LENGTH(sku), sku在排序模型变体时遇到问题:

MANT1
MANT2
MANT3
MANT9
MANT12
MANT13
MANT21
MANT24
MANT29
MANT2C
MANT2D
MANT2W
MANT4C
MANT12C
MANT12P
MANT24D
MANT12CL

那么,有没有办法像 Finder 那样对这些东西进行排序?

(此外,一旦排序,有没有办法获得下一个和上一个产品?我不介意使用几个查询:此时优雅是我的最后一个问题......)

提前谢谢大家。


最后一件事:在我的搜索过程中,我找到了一个类似问题的答案, 但我不知道如何在 PHP 中使用它,所以我不知道它是否有效,实际上是我的问题的答案。

4

2 回答 2

1

你在获取数据时使用 PHP 吗?

如果是这样,在数据已经加载后尝试使用自然排序功能进行内存排序?

于 2013-03-21T12:43:49.840 回答
0

顺序不是“完全错误”,它只取决于您使用的排序规则。在您的情况下,您可以尝试二进制排序规则,例如“latin1_bin”。

以下示例 ORDER BY 使用 COLLATE 处理 UTF8 数据:

mysql> SELECT c1 FROM t1 ORDER BY c1;
+------+
| c1   |
+------+
| a1   |
| a12  |
| a13c |
| a2   |
| a21  |
+------+

mysql> SELECT c1 FROM t1 ORDER BY c1 COLLATE 'utf8_bin';
+------+
| c1   |
+------+
| a1   |
| a12  |
| a2   |
| a21  |
| a13c |
+------+
于 2013-03-21T12:50:39.540 回答