使用 SQLite3,我试图通过将 TEXT 字符串转换为 INTEGER 来对结果进行排序。这是我的查询:
SELECT id,section FROM contract_sections ORDER BY CAST (section AS int)
'section' 列是 TEXT,由分层/规范标识符组成,即 1.2.1,其中每个小数反映层次结构中的另一个深度级别。我希望我的结果按顺序返回(即 1.2.8、1.2.9、1.2.10 等)。如果我只是按“部分”列而不进行强制转换,我会得到如下所示的结果:
1.1, 1.10, 1.2, ...
但是通过前面提到的带有 cast 的查询,它现在似乎可以正确排序,如下所示:
1.1, 1.2, ... 1.9, 1.10
我的问题是,如果我将此字符串转换为 int,SQLite 会将其转换为什么值,结果将如何排序?目前它似乎正在按我的意愿订购东西,但想避免任何不可预见的错误。