gpt4 book ai didi

MySQL:存储包含连字符的 Amazon.com 订单号

转载 作者:太空宇宙 更新时间:2023-11-03 10:23:12 27 4
gpt4 key购买 nike

我遇到一个问题,我需要将 Amazon.com 的订单号存储到 MySQL 表中。 Amazon.com 订单号由数字和连字符组成,例如 102-1234567-1234567(17 个数字和 2 个连字符)。由于某些情况下的连字符,我看到这个“数字”存储为字符串,随后,对该列的搜索是字符串搜索而不是数字搜索。

现在,我只是将它们存储为 VARCHAR(19),但是有没有一种方法可以存储它以便在存储和检索时更高效、更快速?例如,我想过将每个数字段解析成它自己的一列(一个订单“数字”总共 3 列)并执行 ... WHERE colA=102 AND colB=1234567 AND colC=1234567 提取特定订单,而不是执行 ...WHERE col LIKE '102-1234567-1234567'。我知道前者使用的字节少得多,但它也更快吗?我正在处理的表有超过 10 万行,而且每天都在增长一小部分。

关于我应该如何修改结构或不应该如何修改的任何建议或意见? TIA!

最佳答案

这些订单号实际上不是数字。这些是字符串,因此应存储为字符串。

我不知道 Amazon 订单的详细信息,但如果它们的长度始终为 19 个字符,您可以使用 CHAR(19) 代替 VARCHAR(19) 以及使用 ASCII 字符集代替任何多字节。那应该使它更快一点。此外,创建一个将完全覆盖该列的索引(即长度为 19)也可能有助于提高性能,以及使用 = 而不是 LIKE

关于MySQL:存储包含连字符的 Amazon.com 订单号,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8887612/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com