在PostgreSQL数据库中存储semver版本字符串以进行范围查询

时间:2018-11-07 10:13:11

标签: javascript postgresql algorithm serialization

我正在构建的应用程序要求向其应用程序版本与为内容记录指定的范围匹配的用户显示特定内容。

该应用程序使用语义版本控制(例如1.2.31.0.13.7.5)。

我想将1.2.3的字符串值转换为整数,以便创建一个包含最小和最大版本的范围列,以方便查询。

当前,我正在使用以下javascript实现,该实现会产生大量结果,并且还将次要版本和补丁版本限制为999(实际上我可以使用后者)。

export function convertVersionToInt(version) {
  const parts = version.split('.')
  if (parts.length !== 3) {
    throw new Error('Received invalid version string')
  }
  parts.forEach(part => {
    if (part.length > 3) {
      throw new Error(`Version string invalid, ${part} is too large.`)
    }
  })
  const [major, minor, patch] = parts
  return parseInt(
    [major, minor.padStart(3, '0'), patch.padStart(3, '0')].join(''),
    10
  )
}

export function convertIntVersionToString(v) {
  const stringifiedNumber = String(v).padStart(7, '0')

  const length = stringifiedNumber.length
  const patch = parseInt(stringifiedNumber.substr(length - 3, 3), 10)
  const minor = parseInt(stringifiedNumber.substr(length - 6, 3), 10)
  const major = stringifiedNumber.substr(0, length - 6)
  return `${major}.${minor}.${patch}`
}

const v120 = convertVersionToInt('1.2.0')
const v120S = convertIntVersionToString(v120)
console.log(v120, v120S) // 1002000 '1.2.0'
const v1121 = convertVersionToInt('11.2.1')
const v1121S = convertIntVersionToString(v1121)
console.log(v1121, v1121S) // 11002001 '11.2.0'
const v001 = convertVersionToInt('0.0.1')
const v001s = convertIntVersionToString(v001)
console.log(v001, v001s) // 1 '0.0.1'

我想知道是否存在一种更有效的方法来将semver版本序列化为整数(或允许范围查询的其他值)。每个版本部分(主要,次要,补丁)的位数限制是很好的,但是产生的数字必须正确增加。例如。 1.2.0产生的数字必须大于0.0.1

提前感谢您的输入!

1 个答案:

答案 0 :(得分:1)

如果您可以控制数据库模式,则pg-semver可能对您有用:https://github.com/theory/pg-semver它允许使用semver数据类型,并且您可以使用预期的比较运算符来进行版本检查。