当前位置: 首页 > 面试题库 >

在MySQL中以数字方式对varchar字段进行排序

谭嘉容
2023-03-14
问题内容

我有一个number类型字段varchar。即使它是type
varchar,它也存储带有可选前导零的整数值。排序按字典顺序排序("42"在之前"9")。如何订购的数值("9"来之前"42")?

当前,我使用查询:

SELECT * FROM table ORDER BY number ASC

问题答案:

有几种方法可以做到这一点:

  1. 将它们存储为数值而不是字符串。您已经打折了,因为您希望保持字符串像00100完整的前导零。
  2. 按字符串顺序转换为数字。这将起作用,但请注意,这对于大型数据库而言是性能的杀手er。每行函数的扩展性不是很好。
  3. 添加第三列,该列与该字符串和索引的数字等效。然后使用insert/ update触发器来确保每当字符串列更改时就正确设置了它。

由于绝大多数数据库的读取比写入的频率要高,因此上述第三个选项会摊销所有选择的计算成本(在insert/处完成update)。您的选择将使用数字列进行排序(并且没有逐行函数),因此速度之快令人目眩。

您的插入和更新将比较慢,但这就是您要付出的代价,老实说,这是值得付出的。

触发器的使用保持了表的ACID属性,因为这两列保持同步。这是一个众所周知的习惯用法,您通常可以在大多数性能优化中以空间换取时间。

我们在很多情况下都使用了这种“技巧”,例如将姓氏的小写形式与原始tolower文字一起存储(而不是使用),标识字符串的长度以查找所有7个字符的用户(而不是使用len)等等。

请记住,只要您了解(并减轻)后果,就可以从第三种正常形式恢复性能。



 类似资料:
  • 我想根据数字字段对搜索结果进行排序。在下面的示例代码中,我希望基于'Age'字段进行排序。我从以下答案开始: [如何在Lucene 6中对IntPont或LongPoint字段进行排序 [在Lucene中根据数字字段对搜索结果进行排序 我在搜索函数中将sortfield.type.score更改为sortfield.type.long。但我得到: 意外的docvalues为字段“年龄”键入NONE

  • 问题内容: 我正在使用SQL Server,该列为a ,我想像这样对它进行排序: 到目前为止,我有: 但是此SQL语句将“ 14 Draft”放在“ 26”之后。 有人可以帮忙吗?谢谢 问题答案: 您的WHERE陈述很复杂。 看来您想按整数顺序对所有前导数字进行排序,然后再对其余部分进行排序。如果是这样,则应将其作为单独的子句进行操作,而不是尝试一并完成。您遇到的特定问题是,您只允许输入一个数字,

  • 本文向大家介绍MySQL查询以字符串字段中的数字字符对行进行分组?,包括了MySQL查询以字符串字段中的数字字符对行进行分组?的使用技巧和注意事项,需要的朋友参考一下 为此,您可以在+运算符的帮助下将0与字符串字段连接起来。这里的场景就像我们需要从字符串字段“ 9844Bob ”中获取数字“ 9844 ”。 让我们首先创建一个表- 使用插入命令在表中插入一些记录- 使用select语句显示表中的所

  • 问题内容: 我正在尝试获得一个函数,如果您对它进行排序(列表名),它将对该列表中的所有数字进行从最小到最大的排序。 我不确定我的问题是什么,但是我需要一些帮助,因为输出实际上并不是最小到最大,对于输出的前两个数字来说,它最小到最大。 范例: 如果list中有23、212、44个,而不是我对它进行排序,则输出将是这样。 输出: 212,23,44 它 应该是 23、44、212。 码: 更多代码:

  • 问题内容: 我有一些文档有两个字段:文本,计数。 我曾经为文档编制索引,现在我想在文本中搜索并按降序将结果按计数排序。我怎样才能做到这一点? 问题答案: Apache Lucene的默认搜索实现返回按分数(最相关的结果排在最前),然后按ID(最旧的结果排在前)的结果。 可以在查询时使用附加的Sort参数自定义此行为。 TopFieldDocs Searcher#search(查询查询,过滤器过滤器

  • 问题内容: 如何按其字段之一(例如或)对对象数组进行排序? 问题答案: 使用usort,这是从手册改编而成的示例: 您还可以将任何callable用作第二个参数。这里有些例子: 使用匿名函数(来自PHP 5.3) 从班级内部 使用箭头函数(来自PHP 7.4) 另外,如果要比较数字值,则应使用“比较”功能。