如何在MySQL中比较版本字符串(“ xyz”)?

如何在MySQL中比较版本字符串(“ xyz”)?,第1张

如何在MySQL中比较版本字符串(“ xyz”)?

最终,我找到了对版本字符串进行排序的另一种方法。

在将字符串以可排序的方式存储到数据库之前,我先对其进行了对齐。当我使用python
Django框架时,我刚刚创建了一个VersionField,用于在存储时对版本字符串进行“编码”,在读取时对其进行“解码”,因此对于应用程序而言是完全透明的:

这是我的代码:

The justify function :def vjust(str,level=5,delim='.',bitsize=6,fillchar=' '):    """    1.12 becomes : 1.    12    1.1  becomes : 1.     1    """    nb = str.count(delim)    if nb < level:        str += (level-nb) * delim    return delim.join([ v.rjust(bitsize,fillchar) for v in str.split(delim)[:level+1] ])The django VersionField :class VersionField(models.CharField) :    description = 'Field to store version strings ("a.b.c.d") in a way it is sortable'    __metaclass__ = models.Subfieldbase    def get_prep_value(self, value):        return vjust(value,fillchar=' ')    def to_python(self, value):        return re.sub('.+$','',value.replace(' ',''))


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5661638.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-16
下一篇 2022-12-16

发表评论

登录后才能评论

评论列表(0条)

保存