Nexus 3 查询构建器如何按降序检索人工制品

Nexus 3 Query builder how to retrieve artefacts in descending order

有没有一种方法可以按日期降序检索人工制品?

我目前以下面的脚本为例:

import org.sonatype.nexus.repository.storage.Asset
import org.sonatype.nexus.repository.storage.Query
import org.sonatype.nexus.repository.storage.StorageFacet

import groovy.json.JsonOutput
import groovy.json.JsonSlurper

def request = new JsonSlurper().parseText(args)
assert request.groupId: 'groupId parameter is required'
assert request.repoName: 'repoName parameter is required'
assert request.startDate: 'startDate parameter is required, format: yyyy-mm-dd'

log.info("Gathering Asset list for repository: ${request.repoName} as of startDate: ${request.startDate}")

def repo = repository.repositoryManager.get(request.repoName)
StorageFacet storageFacet = repo.facet(StorageFacet)
def tx = storageFacet.txSupplier().get()

tx.begin()

Iterable<Asset> assets = tx.
    findAssets(Query.builder()
      .where('group = ').param(request.groupId)
      .and('last_updated > ').param(request.startDate)
      .build(), [repo])
def urls = assets.collect { "/repository/${repo.name}/${it.name()}" }

tx.commit()

def result = JsonOutput.toJson([
    assets  : urls,
    since   : request.startDate,
    repoName: request.repoName
])
return result

与:

Query.builder()
          .where('group = ').param(request.groupId)
          .and('last_updated > ').param(request.startDate)
          .build()
def urls = assets.collect { "/repository/${repo.name}/${it.name()}" }

有没有办法可以更改上面的脚本以按日期降序检索内容?

您可以简单地添加一个后缀。

Query.builder()
          .where('group = ').param(request.groupId)
          .and('last_updated > ').param(request.startDate)
          .suffix('order by last_updated desc')
          .build()
def urls = assets.collect { "/repository/${repo.name}/${it.name()}" }

Nexus 在后台使用 OrientDB。您可以在此处找到查询示例: https://orientdb.com/docs/2.0/orientdb.wiki/Tutorial-SQL.html