使用类型化uuids而不是字符串uuids查询portal_catalog

时间:2012-04-13 08:32:58

标签: python plone uuid

我正在编写一个Plone日历模块,用于保留不同的资源。此模块具有日历,其事件存储在Postgresql中。每个日历都是存储在ZODB中的Dexterity对象。

要在Plone和Postgresql之间建立链接,我自然会转向Plone对象的uuid属性。所以Plone中的每个uuid都是Postgresql中的外键,它本身支持uuid。

在我开始使用Plone 4.1.4之前,这对我来说效果很好。有了它,引入了plone.uuid 1.0.2,它将uuids的字符串表示从 更改为uuids 而不用破折号。

此更改的问题在于我无法确定哪个表示将用于任何给定对象。在Plone 4.1.4之前创建的对象包含一个不同格式的uuid-string,而不是在。

之后创建的对象

长话短说,为了确保我的代码适用于任何uuid表示,我希望能够使用Python的uuid类型进行搜索。

所以不是这样:

catalog.searchResults(UID='325dc47e-08f9-4fa1-bc18-3944a725adb4')

返回不同的结果:

catalog.searchResults(UID='325dc47e08f94fa1bc183944a725adb4')

我很乐意这样做:

from uuid import UUID
catalog.searchResults(UID=UUID('325dc47e-08f9-4fa1-bc18-3944a725adb4'))

等同于

catalog.searchResults(UID=UUID('325dc47e08f94fa1bc183944a725adb4'))

有没有人知道如何通过uuid在Plone中的表现来实现这种独立性?

1 个答案:

答案 0 :(得分:3)

您必须查询这两种格式;一旦分配了UID字段,就不应该更改它。因此,您的选择是:

  1. 创建一个方法,给定UID返回一个包含虚线和非虚线版本的元组,然后用于查询目录:

    def queryUID(UID):
        if '-' in UID:
            return (UID.replace('-', ''), UID)
        return (UID, '-'.join([
            UID[:8], UID[8:12], UID[12:16], UID[16:20], UID[20:]]))
    

    使用该方法,查询只会变为:

    catalog.searchResults(UID=queryUID('325dc47e-08f9-4fa1-bc18-3944a725adb4'))
    
  2. 使您的数据库使用虚线版本,其中Plone UID有破折号,非虚线版本,其中较旧的Plone内容仍然具有不带破折号的UID。换句话说,将UID视为不透明的字符串。

    Plone中的UID在任何情况下都不会改变,因此在生成虚线版本时,您不必搜索非虚线版本。将UID分配给对象后,它永远不会更改,永远不会获得破折号。

  3. 不推荐遍历您的ZODB并使用虚线等效替换所有UID而不使用破折号。这很可能会破坏通过UID链接到这些项目的任何其他内容。