SQLite ORDER BY字符串,包含以0开头的数字
正如标题所述:
我有一个选择查询,我试图“按顺序”包含数字的字段,事实是这些数字实际上是以0开头的字符串,所以“order by”就是这样做的… ... 10 11 12 01 02 03 ... 有什么想法吗? 编辑:如果我这样做:“… ORDER BY(字段1)”我可以解决这个问题,因为不知何故,字符串在内部被转换为整数.这是一种像C’s atoi一样“正式”转换它的方法吗? 您可以使用CAST http://www.sqlite.org/lang_expr.html#castexpr将表达式强制转换为整数.sqlite> CREATE TABLE T (value VARCHAR(2)); sqlite> INSERT INTO T (value) VALUES ('10'); sqlite> INSERT INTO T (value) VALUES ('11'); sqlite> INSERT INTO T (value) VALUES ('12'); sqlite> INSERT INTO T (value) VALUES ('01'); sqlite> INSERT INTO T (value) VALUES ('02'); sqlite> INSERT INTO T (value) VALUES ('03'); sqlite> SELECT * FROM T ORDER BY CAST(value AS INTEGER); 01 02 03 10 11 12 sqlite>
这很有意思,虽然我不知道有多少DBMS支持这样的操作所以我不推荐它,以防你需要使用不支持它的不同系统,更不用说你正在添加额外的操作,这可能会影响性能,但你也这样做ORDER BY(字段0)我将调查性能 取自sqlite3文档:
我很好奇所以我跑了一些基准: >>> setup = """ ... import sqlite3 ... import timeit ... ... conn = sqlite3.connect(':memory:') ... c = conn.cursor() ... c.execute('CREATE TABLE T (value int)') ... for index in range(4000000,-1): ... _ = c.execute('INSERT INTO T (value) VALUES (%i)' % index) ... conn.commit() ... """ >>> >>> cast_conv = "result = c.execute('SELECT * FROM T ORDER BY CAST(value AS INTEGER)')" >>> cast_affinity = "result = c.execute('SELECT * FROM T ORDER BY (value + 0)')" >>> timeit.Timer(cast_conv,setup).timeit(number = 1) 18.145697116851807 >>> timeit.Timer(cast_affinity,setup).timeit(number = 1) 18.259973049163818 >>> 我们可以看到它有点慢,虽然不是很多,有趣. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |