为什么opencms使用java代码来排序内容文档,而不是使用sql,比如“date desc,name asc”?

时间:2013-08-09 03:57:05

标签: java opencms

我想知道是否还有一些其他技术可以懒散地使用?似乎很难定义一个新的比较器。 以下是CmsDateResourceComparator比较方法的代码:

    public int compare(CmsResource res0, CmsResource res1) {

    if (res0 == res1) {
        return 0;
    }

    CmsDateResourceComparator key0 = m_keys.get(res0.getStructureId());
    CmsDateResourceComparator key1 = m_keys.get(res1.getStructureId());

    if (key0 == null) {
        // initialize key if null
        key0 = CmsDateResourceComparator.create(m_cms, res0, m_dateIdentifiers);
        m_keys.put(res0.getStructureId(), key0);
    }
    if (key1 == null) {
        // initialize key if null
        key1 = CmsDateResourceComparator.create(m_cms, res1, m_dateIdentifiers);
        m_keys.put(res1.getStructureId(), key1);
    }

    if (m_asc) {
        // sort in ascending order
        if (key0.m_date > key1.m_date) {
            return 1;
        }
        if (key0.m_date < key1.m_date) {
            return -1;
        }
    } else {
        // sort in descending order
        if (key0.m_date > key1.m_date) {
            return -1;
        }
        if (key0.m_date < key1.m_date) {
            return 1;
        }
    }

1 个答案:

答案 0 :(得分:1)

从OpenCms 8开始,您可以使用Solr byQuery 收集器。使用此收集器,您可以执行solr查询。这是一个强大的功能......

<cms:contentload collector="byQuery" 2 param="type:v8flower"> 
    <cms:contentaccess var="content" /> 
    ${content.value.Title} 
</cms:contentload>