All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.liferay.fragment.service.persistence.impl.FragmentEntryLinkPersistenceImpl Maven / Gradle / Ivy

/**
 * SPDX-FileCopyrightText: (c) 2000 Liferay, Inc. https://liferay.com
 * SPDX-License-Identifier: LGPL-2.1-or-later OR LicenseRef-Liferay-DXP-EULA-2.0.0-2023-06
 */

package com.liferay.fragment.service.persistence.impl;

import com.liferay.fragment.exception.DuplicateFragmentEntryLinkExternalReferenceCodeException;
import com.liferay.fragment.exception.NoSuchEntryLinkException;
import com.liferay.fragment.model.FragmentEntryLink;
import com.liferay.fragment.model.FragmentEntryLinkTable;
import com.liferay.fragment.model.impl.FragmentEntryLinkImpl;
import com.liferay.fragment.model.impl.FragmentEntryLinkModelImpl;
import com.liferay.fragment.service.persistence.FragmentEntryLinkPersistence;
import com.liferay.fragment.service.persistence.FragmentEntryLinkUtil;
import com.liferay.fragment.service.persistence.impl.constants.FragmentPersistenceConstants;
import com.liferay.petra.lang.SafeCloseable;
import com.liferay.petra.string.StringBundler;
import com.liferay.portal.kernel.change.tracking.CTCollectionThreadLocal;
import com.liferay.portal.kernel.change.tracking.CTColumnResolutionType;
import com.liferay.portal.kernel.configuration.Configuration;
import com.liferay.portal.kernel.dao.orm.EntityCache;
import com.liferay.portal.kernel.dao.orm.FinderCache;
import com.liferay.portal.kernel.dao.orm.FinderPath;
import com.liferay.portal.kernel.dao.orm.Query;
import com.liferay.portal.kernel.dao.orm.QueryPos;
import com.liferay.portal.kernel.dao.orm.QueryUtil;
import com.liferay.portal.kernel.dao.orm.Session;
import com.liferay.portal.kernel.dao.orm.SessionFactory;
import com.liferay.portal.kernel.exception.SystemException;
import com.liferay.portal.kernel.log.Log;
import com.liferay.portal.kernel.log.LogFactoryUtil;
import com.liferay.portal.kernel.sanitizer.Sanitizer;
import com.liferay.portal.kernel.sanitizer.SanitizerException;
import com.liferay.portal.kernel.sanitizer.SanitizerUtil;
import com.liferay.portal.kernel.security.auth.CompanyThreadLocal;
import com.liferay.portal.kernel.security.auth.PrincipalThreadLocal;
import com.liferay.portal.kernel.service.ServiceContext;
import com.liferay.portal.kernel.service.ServiceContextThreadLocal;
import com.liferay.portal.kernel.service.persistence.change.tracking.helper.CTPersistenceHelper;
import com.liferay.portal.kernel.service.persistence.impl.BasePersistenceImpl;
import com.liferay.portal.kernel.util.ArrayUtil;
import com.liferay.portal.kernel.util.ContentTypes;
import com.liferay.portal.kernel.util.GetterUtil;
import com.liferay.portal.kernel.util.OrderByComparator;
import com.liferay.portal.kernel.util.PropsKeys;
import com.liferay.portal.kernel.util.PropsUtil;
import com.liferay.portal.kernel.util.ProxyUtil;
import com.liferay.portal.kernel.util.SetUtil;
import com.liferay.portal.kernel.util.StringUtil;
import com.liferay.portal.kernel.util.Validator;
import com.liferay.portal.kernel.uuid.PortalUUIDUtil;

import java.io.Serializable;

import java.lang.reflect.InvocationHandler;

import java.util.ArrayList;
import java.util.Collections;
import java.util.Date;
import java.util.EnumMap;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Objects;
import java.util.Set;

import javax.sql.DataSource;

import org.osgi.service.component.annotations.Activate;
import org.osgi.service.component.annotations.Component;
import org.osgi.service.component.annotations.Deactivate;
import org.osgi.service.component.annotations.Reference;

/**
 * The persistence implementation for the fragment entry link service.
 *
 * 

* Caching information and settings can be found in portal.properties *

* * @author Brian Wing Shun Chan * @generated */ @Component(service = FragmentEntryLinkPersistence.class) public class FragmentEntryLinkPersistenceImpl extends BasePersistenceImpl implements FragmentEntryLinkPersistence { /* * NOTE FOR DEVELOPERS: * * Never modify or reference this class directly. Always use FragmentEntryLinkUtil to access the fragment entry link persistence. Modify service.xml and rerun ServiceBuilder to regenerate this class. */ public static final String FINDER_CLASS_NAME_ENTITY = FragmentEntryLinkImpl.class.getName(); public static final String FINDER_CLASS_NAME_LIST_WITH_PAGINATION = FINDER_CLASS_NAME_ENTITY + ".List1"; public static final String FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION = FINDER_CLASS_NAME_ENTITY + ".List2"; private FinderPath _finderPathWithPaginationFindAll; private FinderPath _finderPathWithoutPaginationFindAll; private FinderPath _finderPathCountAll; private FinderPath _finderPathWithPaginationFindByUuid; private FinderPath _finderPathWithoutPaginationFindByUuid; private FinderPath _finderPathCountByUuid; /** * Returns all the fragment entry links where uuid = ?. * * @param uuid the uuid * @return the matching fragment entry links */ @Override public List findByUuid(String uuid) { return findByUuid(uuid, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null); } /** * Returns a range of all the fragment entry links where uuid = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param uuid the uuid * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @return the range of matching fragment entry links */ @Override public List findByUuid(String uuid, int start, int end) { return findByUuid(uuid, start, end, null); } /** * Returns an ordered range of all the fragment entry links where uuid = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param uuid the uuid * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @return the ordered range of matching fragment entry links */ @Override public List findByUuid( String uuid, int start, int end, OrderByComparator orderByComparator) { return findByUuid(uuid, start, end, orderByComparator, true); } /** * Returns an ordered range of all the fragment entry links where uuid = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param uuid the uuid * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @param useFinderCache whether to use the finder cache * @return the ordered range of matching fragment entry links */ @Override public List findByUuid( String uuid, int start, int end, OrderByComparator orderByComparator, boolean useFinderCache) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { uuid = Objects.toString(uuid, ""); FinderPath finderPath = null; Object[] finderArgs = null; if ((start == QueryUtil.ALL_POS) && (end == QueryUtil.ALL_POS) && (orderByComparator == null)) { if (useFinderCache) { finderPath = _finderPathWithoutPaginationFindByUuid; finderArgs = new Object[] {uuid}; } } else if (useFinderCache) { finderPath = _finderPathWithPaginationFindByUuid; finderArgs = new Object[] {uuid, start, end, orderByComparator}; } List list = null; if (useFinderCache) { list = (List)finderCache.getResult( finderPath, finderArgs, this); if ((list != null) && !list.isEmpty()) { for (FragmentEntryLink fragmentEntryLink : list) { if (!uuid.equals(fragmentEntryLink.getUuid())) { list = null; break; } } } } if (list == null) { StringBundler sb = null; if (orderByComparator != null) { sb = new StringBundler( 3 + (orderByComparator.getOrderByFields().length * 2)); } else { sb = new StringBundler(3); } sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); boolean bindUuid = false; if (uuid.isEmpty()) { sb.append(_FINDER_COLUMN_UUID_UUID_3); } else { bindUuid = true; sb.append(_FINDER_COLUMN_UUID_UUID_2); } if (orderByComparator != null) { appendOrderByComparator( sb, _ORDER_BY_ENTITY_ALIAS, orderByComparator); } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); if (bindUuid) { queryPos.add(uuid); } list = (List)QueryUtil.list( query, getDialect(), start, end); cacheResult(list); if (useFinderCache) { finderCache.putResult(finderPath, finderArgs, list); } } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return list; } } /** * Returns the first fragment entry link in the ordered set where uuid = ?. * * @param uuid the uuid * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByUuid_First( String uuid, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByUuid_First( uuid, orderByComparator); if (fragmentEntryLink != null) { return fragmentEntryLink; } StringBundler sb = new StringBundler(4); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("uuid="); sb.append(uuid); sb.append("}"); throw new NoSuchEntryLinkException(sb.toString()); } /** * Returns the first fragment entry link in the ordered set where uuid = ?. * * @param uuid the uuid * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByUuid_First( String uuid, OrderByComparator orderByComparator) { List list = findByUuid( uuid, 0, 1, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the last fragment entry link in the ordered set where uuid = ?. * * @param uuid the uuid * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByUuid_Last( String uuid, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByUuid_Last( uuid, orderByComparator); if (fragmentEntryLink != null) { return fragmentEntryLink; } StringBundler sb = new StringBundler(4); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("uuid="); sb.append(uuid); sb.append("}"); throw new NoSuchEntryLinkException(sb.toString()); } /** * Returns the last fragment entry link in the ordered set where uuid = ?. * * @param uuid the uuid * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByUuid_Last( String uuid, OrderByComparator orderByComparator) { int count = countByUuid(uuid); if (count == 0) { return null; } List list = findByUuid( uuid, count - 1, count, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the fragment entry links before and after the current fragment entry link in the ordered set where uuid = ?. * * @param fragmentEntryLinkId the primary key of the current fragment entry link * @param uuid the uuid * @param orderByComparator the comparator to order the set by (optionally null) * @return the previous, current, and next fragment entry link * @throws NoSuchEntryLinkException if a fragment entry link with the primary key could not be found */ @Override public FragmentEntryLink[] findByUuid_PrevAndNext( long fragmentEntryLinkId, String uuid, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { uuid = Objects.toString(uuid, ""); FragmentEntryLink fragmentEntryLink = findByPrimaryKey( fragmentEntryLinkId); Session session = null; try { session = openSession(); FragmentEntryLink[] array = new FragmentEntryLinkImpl[3]; array[0] = getByUuid_PrevAndNext( session, fragmentEntryLink, uuid, orderByComparator, true); array[1] = fragmentEntryLink; array[2] = getByUuid_PrevAndNext( session, fragmentEntryLink, uuid, orderByComparator, false); return array; } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } protected FragmentEntryLink getByUuid_PrevAndNext( Session session, FragmentEntryLink fragmentEntryLink, String uuid, OrderByComparator orderByComparator, boolean previous) { StringBundler sb = null; if (orderByComparator != null) { sb = new StringBundler( 4 + (orderByComparator.getOrderByConditionFields().length * 3) + (orderByComparator.getOrderByFields().length * 3)); } else { sb = new StringBundler(3); } sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); boolean bindUuid = false; if (uuid.isEmpty()) { sb.append(_FINDER_COLUMN_UUID_UUID_3); } else { bindUuid = true; sb.append(_FINDER_COLUMN_UUID_UUID_2); } if (orderByComparator != null) { String[] orderByConditionFields = orderByComparator.getOrderByConditionFields(); if (orderByConditionFields.length > 0) { sb.append(WHERE_AND); } for (int i = 0; i < orderByConditionFields.length; i++) { sb.append(_ORDER_BY_ENTITY_ALIAS); sb.append(orderByConditionFields[i]); if ((i + 1) < orderByConditionFields.length) { if (orderByComparator.isAscending() ^ previous) { sb.append(WHERE_GREATER_THAN_HAS_NEXT); } else { sb.append(WHERE_LESSER_THAN_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { sb.append(WHERE_GREATER_THAN); } else { sb.append(WHERE_LESSER_THAN); } } } sb.append(ORDER_BY_CLAUSE); String[] orderByFields = orderByComparator.getOrderByFields(); for (int i = 0; i < orderByFields.length; i++) { sb.append(_ORDER_BY_ENTITY_ALIAS); sb.append(orderByFields[i]); if ((i + 1) < orderByFields.length) { if (orderByComparator.isAscending() ^ previous) { sb.append(ORDER_BY_ASC_HAS_NEXT); } else { sb.append(ORDER_BY_DESC_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { sb.append(ORDER_BY_ASC); } else { sb.append(ORDER_BY_DESC); } } } } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Query query = session.createQuery(sql); query.setFirstResult(0); query.setMaxResults(2); QueryPos queryPos = QueryPos.getInstance(query); if (bindUuid) { queryPos.add(uuid); } if (orderByComparator != null) { for (Object orderByConditionValue : orderByComparator.getOrderByConditionValues( fragmentEntryLink)) { queryPos.add(orderByConditionValue); } } List list = query.list(); if (list.size() == 2) { return list.get(1); } else { return null; } } /** * Removes all the fragment entry links where uuid = ? from the database. * * @param uuid the uuid */ @Override public void removeByUuid(String uuid) { for (FragmentEntryLink fragmentEntryLink : findByUuid(uuid, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null)) { remove(fragmentEntryLink); } } /** * Returns the number of fragment entry links where uuid = ?. * * @param uuid the uuid * @return the number of matching fragment entry links */ @Override public int countByUuid(String uuid) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { uuid = Objects.toString(uuid, ""); FinderPath finderPath = _finderPathCountByUuid; Object[] finderArgs = new Object[] {uuid}; Long count = (Long)finderCache.getResult( finderPath, finderArgs, this); if (count == null) { StringBundler sb = new StringBundler(2); sb.append(_SQL_COUNT_FRAGMENTENTRYLINK_WHERE); boolean bindUuid = false; if (uuid.isEmpty()) { sb.append(_FINDER_COLUMN_UUID_UUID_3); } else { bindUuid = true; sb.append(_FINDER_COLUMN_UUID_UUID_2); } String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); if (bindUuid) { queryPos.add(uuid); } count = (Long)query.uniqueResult(); finderCache.putResult(finderPath, finderArgs, count); } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return count.intValue(); } } private static final String _FINDER_COLUMN_UUID_UUID_2 = "fragmentEntryLink.uuid = ?"; private static final String _FINDER_COLUMN_UUID_UUID_3 = "(fragmentEntryLink.uuid IS NULL OR fragmentEntryLink.uuid = '')"; private FinderPath _finderPathFetchByUUID_G; private FinderPath _finderPathCountByUUID_G; /** * Returns the fragment entry link where uuid = ? and groupId = ? or throws a NoSuchEntryLinkException if it could not be found. * * @param uuid the uuid * @param groupId the group ID * @return the matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByUUID_G(String uuid, long groupId) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByUUID_G(uuid, groupId); if (fragmentEntryLink == null) { StringBundler sb = new StringBundler(6); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("uuid="); sb.append(uuid); sb.append(", groupId="); sb.append(groupId); sb.append("}"); if (_log.isDebugEnabled()) { _log.debug(sb.toString()); } throw new NoSuchEntryLinkException(sb.toString()); } return fragmentEntryLink; } /** * Returns the fragment entry link where uuid = ? and groupId = ? or returns null if it could not be found. Uses the finder cache. * * @param uuid the uuid * @param groupId the group ID * @return the matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByUUID_G(String uuid, long groupId) { return fetchByUUID_G(uuid, groupId, true); } /** * Returns the fragment entry link where uuid = ? and groupId = ? or returns null if it could not be found, optionally using the finder cache. * * @param uuid the uuid * @param groupId the group ID * @param useFinderCache whether to use the finder cache * @return the matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByUUID_G( String uuid, long groupId, boolean useFinderCache) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { uuid = Objects.toString(uuid, ""); Object[] finderArgs = null; if (useFinderCache) { finderArgs = new Object[] {uuid, groupId}; } Object result = null; if (useFinderCache) { result = finderCache.getResult( _finderPathFetchByUUID_G, finderArgs, this); } if (result instanceof FragmentEntryLink) { FragmentEntryLink fragmentEntryLink = (FragmentEntryLink)result; if (!Objects.equals(uuid, fragmentEntryLink.getUuid()) || (groupId != fragmentEntryLink.getGroupId())) { result = null; } } if (result == null) { StringBundler sb = new StringBundler(4); sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); boolean bindUuid = false; if (uuid.isEmpty()) { sb.append(_FINDER_COLUMN_UUID_G_UUID_3); } else { bindUuid = true; sb.append(_FINDER_COLUMN_UUID_G_UUID_2); } sb.append(_FINDER_COLUMN_UUID_G_GROUPID_2); String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); if (bindUuid) { queryPos.add(uuid); } queryPos.add(groupId); List list = query.list(); if (list.isEmpty()) { if (useFinderCache) { finderCache.putResult( _finderPathFetchByUUID_G, finderArgs, list); } } else { FragmentEntryLink fragmentEntryLink = list.get(0); result = fragmentEntryLink; cacheResult(fragmentEntryLink); } } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } if (result instanceof List) { return null; } else { return (FragmentEntryLink)result; } } } /** * Removes the fragment entry link where uuid = ? and groupId = ? from the database. * * @param uuid the uuid * @param groupId the group ID * @return the fragment entry link that was removed */ @Override public FragmentEntryLink removeByUUID_G(String uuid, long groupId) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = findByUUID_G(uuid, groupId); return remove(fragmentEntryLink); } /** * Returns the number of fragment entry links where uuid = ? and groupId = ?. * * @param uuid the uuid * @param groupId the group ID * @return the number of matching fragment entry links */ @Override public int countByUUID_G(String uuid, long groupId) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { uuid = Objects.toString(uuid, ""); FinderPath finderPath = _finderPathCountByUUID_G; Object[] finderArgs = new Object[] {uuid, groupId}; Long count = (Long)finderCache.getResult( finderPath, finderArgs, this); if (count == null) { StringBundler sb = new StringBundler(3); sb.append(_SQL_COUNT_FRAGMENTENTRYLINK_WHERE); boolean bindUuid = false; if (uuid.isEmpty()) { sb.append(_FINDER_COLUMN_UUID_G_UUID_3); } else { bindUuid = true; sb.append(_FINDER_COLUMN_UUID_G_UUID_2); } sb.append(_FINDER_COLUMN_UUID_G_GROUPID_2); String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); if (bindUuid) { queryPos.add(uuid); } queryPos.add(groupId); count = (Long)query.uniqueResult(); finderCache.putResult(finderPath, finderArgs, count); } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return count.intValue(); } } private static final String _FINDER_COLUMN_UUID_G_UUID_2 = "fragmentEntryLink.uuid = ? AND "; private static final String _FINDER_COLUMN_UUID_G_UUID_3 = "(fragmentEntryLink.uuid IS NULL OR fragmentEntryLink.uuid = '') AND "; private static final String _FINDER_COLUMN_UUID_G_GROUPID_2 = "fragmentEntryLink.groupId = ?"; private FinderPath _finderPathWithPaginationFindByUuid_C; private FinderPath _finderPathWithoutPaginationFindByUuid_C; private FinderPath _finderPathCountByUuid_C; /** * Returns all the fragment entry links where uuid = ? and companyId = ?. * * @param uuid the uuid * @param companyId the company ID * @return the matching fragment entry links */ @Override public List findByUuid_C(String uuid, long companyId) { return findByUuid_C( uuid, companyId, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null); } /** * Returns a range of all the fragment entry links where uuid = ? and companyId = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param uuid the uuid * @param companyId the company ID * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @return the range of matching fragment entry links */ @Override public List findByUuid_C( String uuid, long companyId, int start, int end) { return findByUuid_C(uuid, companyId, start, end, null); } /** * Returns an ordered range of all the fragment entry links where uuid = ? and companyId = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param uuid the uuid * @param companyId the company ID * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @return the ordered range of matching fragment entry links */ @Override public List findByUuid_C( String uuid, long companyId, int start, int end, OrderByComparator orderByComparator) { return findByUuid_C( uuid, companyId, start, end, orderByComparator, true); } /** * Returns an ordered range of all the fragment entry links where uuid = ? and companyId = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param uuid the uuid * @param companyId the company ID * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @param useFinderCache whether to use the finder cache * @return the ordered range of matching fragment entry links */ @Override public List findByUuid_C( String uuid, long companyId, int start, int end, OrderByComparator orderByComparator, boolean useFinderCache) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { uuid = Objects.toString(uuid, ""); FinderPath finderPath = null; Object[] finderArgs = null; if ((start == QueryUtil.ALL_POS) && (end == QueryUtil.ALL_POS) && (orderByComparator == null)) { if (useFinderCache) { finderPath = _finderPathWithoutPaginationFindByUuid_C; finderArgs = new Object[] {uuid, companyId}; } } else if (useFinderCache) { finderPath = _finderPathWithPaginationFindByUuid_C; finderArgs = new Object[] { uuid, companyId, start, end, orderByComparator }; } List list = null; if (useFinderCache) { list = (List)finderCache.getResult( finderPath, finderArgs, this); if ((list != null) && !list.isEmpty()) { for (FragmentEntryLink fragmentEntryLink : list) { if (!uuid.equals(fragmentEntryLink.getUuid()) || (companyId != fragmentEntryLink.getCompanyId())) { list = null; break; } } } } if (list == null) { StringBundler sb = null; if (orderByComparator != null) { sb = new StringBundler( 4 + (orderByComparator.getOrderByFields().length * 2)); } else { sb = new StringBundler(4); } sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); boolean bindUuid = false; if (uuid.isEmpty()) { sb.append(_FINDER_COLUMN_UUID_C_UUID_3); } else { bindUuid = true; sb.append(_FINDER_COLUMN_UUID_C_UUID_2); } sb.append(_FINDER_COLUMN_UUID_C_COMPANYID_2); if (orderByComparator != null) { appendOrderByComparator( sb, _ORDER_BY_ENTITY_ALIAS, orderByComparator); } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); if (bindUuid) { queryPos.add(uuid); } queryPos.add(companyId); list = (List)QueryUtil.list( query, getDialect(), start, end); cacheResult(list); if (useFinderCache) { finderCache.putResult(finderPath, finderArgs, list); } } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return list; } } /** * Returns the first fragment entry link in the ordered set where uuid = ? and companyId = ?. * * @param uuid the uuid * @param companyId the company ID * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByUuid_C_First( String uuid, long companyId, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByUuid_C_First( uuid, companyId, orderByComparator); if (fragmentEntryLink != null) { return fragmentEntryLink; } StringBundler sb = new StringBundler(6); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("uuid="); sb.append(uuid); sb.append(", companyId="); sb.append(companyId); sb.append("}"); throw new NoSuchEntryLinkException(sb.toString()); } /** * Returns the first fragment entry link in the ordered set where uuid = ? and companyId = ?. * * @param uuid the uuid * @param companyId the company ID * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByUuid_C_First( String uuid, long companyId, OrderByComparator orderByComparator) { List list = findByUuid_C( uuid, companyId, 0, 1, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the last fragment entry link in the ordered set where uuid = ? and companyId = ?. * * @param uuid the uuid * @param companyId the company ID * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByUuid_C_Last( String uuid, long companyId, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByUuid_C_Last( uuid, companyId, orderByComparator); if (fragmentEntryLink != null) { return fragmentEntryLink; } StringBundler sb = new StringBundler(6); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("uuid="); sb.append(uuid); sb.append(", companyId="); sb.append(companyId); sb.append("}"); throw new NoSuchEntryLinkException(sb.toString()); } /** * Returns the last fragment entry link in the ordered set where uuid = ? and companyId = ?. * * @param uuid the uuid * @param companyId the company ID * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByUuid_C_Last( String uuid, long companyId, OrderByComparator orderByComparator) { int count = countByUuid_C(uuid, companyId); if (count == 0) { return null; } List list = findByUuid_C( uuid, companyId, count - 1, count, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the fragment entry links before and after the current fragment entry link in the ordered set where uuid = ? and companyId = ?. * * @param fragmentEntryLinkId the primary key of the current fragment entry link * @param uuid the uuid * @param companyId the company ID * @param orderByComparator the comparator to order the set by (optionally null) * @return the previous, current, and next fragment entry link * @throws NoSuchEntryLinkException if a fragment entry link with the primary key could not be found */ @Override public FragmentEntryLink[] findByUuid_C_PrevAndNext( long fragmentEntryLinkId, String uuid, long companyId, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { uuid = Objects.toString(uuid, ""); FragmentEntryLink fragmentEntryLink = findByPrimaryKey( fragmentEntryLinkId); Session session = null; try { session = openSession(); FragmentEntryLink[] array = new FragmentEntryLinkImpl[3]; array[0] = getByUuid_C_PrevAndNext( session, fragmentEntryLink, uuid, companyId, orderByComparator, true); array[1] = fragmentEntryLink; array[2] = getByUuid_C_PrevAndNext( session, fragmentEntryLink, uuid, companyId, orderByComparator, false); return array; } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } protected FragmentEntryLink getByUuid_C_PrevAndNext( Session session, FragmentEntryLink fragmentEntryLink, String uuid, long companyId, OrderByComparator orderByComparator, boolean previous) { StringBundler sb = null; if (orderByComparator != null) { sb = new StringBundler( 5 + (orderByComparator.getOrderByConditionFields().length * 3) + (orderByComparator.getOrderByFields().length * 3)); } else { sb = new StringBundler(4); } sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); boolean bindUuid = false; if (uuid.isEmpty()) { sb.append(_FINDER_COLUMN_UUID_C_UUID_3); } else { bindUuid = true; sb.append(_FINDER_COLUMN_UUID_C_UUID_2); } sb.append(_FINDER_COLUMN_UUID_C_COMPANYID_2); if (orderByComparator != null) { String[] orderByConditionFields = orderByComparator.getOrderByConditionFields(); if (orderByConditionFields.length > 0) { sb.append(WHERE_AND); } for (int i = 0; i < orderByConditionFields.length; i++) { sb.append(_ORDER_BY_ENTITY_ALIAS); sb.append(orderByConditionFields[i]); if ((i + 1) < orderByConditionFields.length) { if (orderByComparator.isAscending() ^ previous) { sb.append(WHERE_GREATER_THAN_HAS_NEXT); } else { sb.append(WHERE_LESSER_THAN_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { sb.append(WHERE_GREATER_THAN); } else { sb.append(WHERE_LESSER_THAN); } } } sb.append(ORDER_BY_CLAUSE); String[] orderByFields = orderByComparator.getOrderByFields(); for (int i = 0; i < orderByFields.length; i++) { sb.append(_ORDER_BY_ENTITY_ALIAS); sb.append(orderByFields[i]); if ((i + 1) < orderByFields.length) { if (orderByComparator.isAscending() ^ previous) { sb.append(ORDER_BY_ASC_HAS_NEXT); } else { sb.append(ORDER_BY_DESC_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { sb.append(ORDER_BY_ASC); } else { sb.append(ORDER_BY_DESC); } } } } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Query query = session.createQuery(sql); query.setFirstResult(0); query.setMaxResults(2); QueryPos queryPos = QueryPos.getInstance(query); if (bindUuid) { queryPos.add(uuid); } queryPos.add(companyId); if (orderByComparator != null) { for (Object orderByConditionValue : orderByComparator.getOrderByConditionValues( fragmentEntryLink)) { queryPos.add(orderByConditionValue); } } List list = query.list(); if (list.size() == 2) { return list.get(1); } else { return null; } } /** * Removes all the fragment entry links where uuid = ? and companyId = ? from the database. * * @param uuid the uuid * @param companyId the company ID */ @Override public void removeByUuid_C(String uuid, long companyId) { for (FragmentEntryLink fragmentEntryLink : findByUuid_C( uuid, companyId, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null)) { remove(fragmentEntryLink); } } /** * Returns the number of fragment entry links where uuid = ? and companyId = ?. * * @param uuid the uuid * @param companyId the company ID * @return the number of matching fragment entry links */ @Override public int countByUuid_C(String uuid, long companyId) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { uuid = Objects.toString(uuid, ""); FinderPath finderPath = _finderPathCountByUuid_C; Object[] finderArgs = new Object[] {uuid, companyId}; Long count = (Long)finderCache.getResult( finderPath, finderArgs, this); if (count == null) { StringBundler sb = new StringBundler(3); sb.append(_SQL_COUNT_FRAGMENTENTRYLINK_WHERE); boolean bindUuid = false; if (uuid.isEmpty()) { sb.append(_FINDER_COLUMN_UUID_C_UUID_3); } else { bindUuid = true; sb.append(_FINDER_COLUMN_UUID_C_UUID_2); } sb.append(_FINDER_COLUMN_UUID_C_COMPANYID_2); String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); if (bindUuid) { queryPos.add(uuid); } queryPos.add(companyId); count = (Long)query.uniqueResult(); finderCache.putResult(finderPath, finderArgs, count); } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return count.intValue(); } } private static final String _FINDER_COLUMN_UUID_C_UUID_2 = "fragmentEntryLink.uuid = ? AND "; private static final String _FINDER_COLUMN_UUID_C_UUID_3 = "(fragmentEntryLink.uuid IS NULL OR fragmentEntryLink.uuid = '') AND "; private static final String _FINDER_COLUMN_UUID_C_COMPANYID_2 = "fragmentEntryLink.companyId = ?"; private FinderPath _finderPathWithPaginationFindByGroupId; private FinderPath _finderPathWithoutPaginationFindByGroupId; private FinderPath _finderPathCountByGroupId; /** * Returns all the fragment entry links where groupId = ?. * * @param groupId the group ID * @return the matching fragment entry links */ @Override public List findByGroupId(long groupId) { return findByGroupId( groupId, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null); } /** * Returns a range of all the fragment entry links where groupId = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @return the range of matching fragment entry links */ @Override public List findByGroupId( long groupId, int start, int end) { return findByGroupId(groupId, start, end, null); } /** * Returns an ordered range of all the fragment entry links where groupId = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @return the ordered range of matching fragment entry links */ @Override public List findByGroupId( long groupId, int start, int end, OrderByComparator orderByComparator) { return findByGroupId(groupId, start, end, orderByComparator, true); } /** * Returns an ordered range of all the fragment entry links where groupId = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @param useFinderCache whether to use the finder cache * @return the ordered range of matching fragment entry links */ @Override public List findByGroupId( long groupId, int start, int end, OrderByComparator orderByComparator, boolean useFinderCache) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { FinderPath finderPath = null; Object[] finderArgs = null; if ((start == QueryUtil.ALL_POS) && (end == QueryUtil.ALL_POS) && (orderByComparator == null)) { if (useFinderCache) { finderPath = _finderPathWithoutPaginationFindByGroupId; finderArgs = new Object[] {groupId}; } } else if (useFinderCache) { finderPath = _finderPathWithPaginationFindByGroupId; finderArgs = new Object[] { groupId, start, end, orderByComparator }; } List list = null; if (useFinderCache) { list = (List)finderCache.getResult( finderPath, finderArgs, this); if ((list != null) && !list.isEmpty()) { for (FragmentEntryLink fragmentEntryLink : list) { if (groupId != fragmentEntryLink.getGroupId()) { list = null; break; } } } } if (list == null) { StringBundler sb = null; if (orderByComparator != null) { sb = new StringBundler( 3 + (orderByComparator.getOrderByFields().length * 2)); } else { sb = new StringBundler(3); } sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_GROUPID_GROUPID_2); if (orderByComparator != null) { appendOrderByComparator( sb, _ORDER_BY_ENTITY_ALIAS, orderByComparator); } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); list = (List)QueryUtil.list( query, getDialect(), start, end); cacheResult(list); if (useFinderCache) { finderCache.putResult(finderPath, finderArgs, list); } } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return list; } } /** * Returns the first fragment entry link in the ordered set where groupId = ?. * * @param groupId the group ID * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByGroupId_First( long groupId, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByGroupId_First( groupId, orderByComparator); if (fragmentEntryLink != null) { return fragmentEntryLink; } StringBundler sb = new StringBundler(4); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("groupId="); sb.append(groupId); sb.append("}"); throw new NoSuchEntryLinkException(sb.toString()); } /** * Returns the first fragment entry link in the ordered set where groupId = ?. * * @param groupId the group ID * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByGroupId_First( long groupId, OrderByComparator orderByComparator) { List list = findByGroupId( groupId, 0, 1, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the last fragment entry link in the ordered set where groupId = ?. * * @param groupId the group ID * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByGroupId_Last( long groupId, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByGroupId_Last( groupId, orderByComparator); if (fragmentEntryLink != null) { return fragmentEntryLink; } StringBundler sb = new StringBundler(4); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("groupId="); sb.append(groupId); sb.append("}"); throw new NoSuchEntryLinkException(sb.toString()); } /** * Returns the last fragment entry link in the ordered set where groupId = ?. * * @param groupId the group ID * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByGroupId_Last( long groupId, OrderByComparator orderByComparator) { int count = countByGroupId(groupId); if (count == 0) { return null; } List list = findByGroupId( groupId, count - 1, count, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the fragment entry links before and after the current fragment entry link in the ordered set where groupId = ?. * * @param fragmentEntryLinkId the primary key of the current fragment entry link * @param groupId the group ID * @param orderByComparator the comparator to order the set by (optionally null) * @return the previous, current, and next fragment entry link * @throws NoSuchEntryLinkException if a fragment entry link with the primary key could not be found */ @Override public FragmentEntryLink[] findByGroupId_PrevAndNext( long fragmentEntryLinkId, long groupId, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = findByPrimaryKey( fragmentEntryLinkId); Session session = null; try { session = openSession(); FragmentEntryLink[] array = new FragmentEntryLinkImpl[3]; array[0] = getByGroupId_PrevAndNext( session, fragmentEntryLink, groupId, orderByComparator, true); array[1] = fragmentEntryLink; array[2] = getByGroupId_PrevAndNext( session, fragmentEntryLink, groupId, orderByComparator, false); return array; } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } protected FragmentEntryLink getByGroupId_PrevAndNext( Session session, FragmentEntryLink fragmentEntryLink, long groupId, OrderByComparator orderByComparator, boolean previous) { StringBundler sb = null; if (orderByComparator != null) { sb = new StringBundler( 4 + (orderByComparator.getOrderByConditionFields().length * 3) + (orderByComparator.getOrderByFields().length * 3)); } else { sb = new StringBundler(3); } sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_GROUPID_GROUPID_2); if (orderByComparator != null) { String[] orderByConditionFields = orderByComparator.getOrderByConditionFields(); if (orderByConditionFields.length > 0) { sb.append(WHERE_AND); } for (int i = 0; i < orderByConditionFields.length; i++) { sb.append(_ORDER_BY_ENTITY_ALIAS); sb.append(orderByConditionFields[i]); if ((i + 1) < orderByConditionFields.length) { if (orderByComparator.isAscending() ^ previous) { sb.append(WHERE_GREATER_THAN_HAS_NEXT); } else { sb.append(WHERE_LESSER_THAN_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { sb.append(WHERE_GREATER_THAN); } else { sb.append(WHERE_LESSER_THAN); } } } sb.append(ORDER_BY_CLAUSE); String[] orderByFields = orderByComparator.getOrderByFields(); for (int i = 0; i < orderByFields.length; i++) { sb.append(_ORDER_BY_ENTITY_ALIAS); sb.append(orderByFields[i]); if ((i + 1) < orderByFields.length) { if (orderByComparator.isAscending() ^ previous) { sb.append(ORDER_BY_ASC_HAS_NEXT); } else { sb.append(ORDER_BY_DESC_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { sb.append(ORDER_BY_ASC); } else { sb.append(ORDER_BY_DESC); } } } } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Query query = session.createQuery(sql); query.setFirstResult(0); query.setMaxResults(2); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); if (orderByComparator != null) { for (Object orderByConditionValue : orderByComparator.getOrderByConditionValues( fragmentEntryLink)) { queryPos.add(orderByConditionValue); } } List list = query.list(); if (list.size() == 2) { return list.get(1); } else { return null; } } /** * Removes all the fragment entry links where groupId = ? from the database. * * @param groupId the group ID */ @Override public void removeByGroupId(long groupId) { for (FragmentEntryLink fragmentEntryLink : findByGroupId( groupId, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null)) { remove(fragmentEntryLink); } } /** * Returns the number of fragment entry links where groupId = ?. * * @param groupId the group ID * @return the number of matching fragment entry links */ @Override public int countByGroupId(long groupId) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { FinderPath finderPath = _finderPathCountByGroupId; Object[] finderArgs = new Object[] {groupId}; Long count = (Long)finderCache.getResult( finderPath, finderArgs, this); if (count == null) { StringBundler sb = new StringBundler(2); sb.append(_SQL_COUNT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_GROUPID_GROUPID_2); String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); count = (Long)query.uniqueResult(); finderCache.putResult(finderPath, finderArgs, count); } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return count.intValue(); } } private static final String _FINDER_COLUMN_GROUPID_GROUPID_2 = "fragmentEntryLink.groupId = ?"; private FinderPath _finderPathWithPaginationFindByFragmentEntryId; private FinderPath _finderPathWithoutPaginationFindByFragmentEntryId; private FinderPath _finderPathCountByFragmentEntryId; private FinderPath _finderPathWithPaginationCountByFragmentEntryId; /** * Returns all the fragment entry links where fragmentEntryId = ?. * * @param fragmentEntryId the fragment entry ID * @return the matching fragment entry links */ @Override public List findByFragmentEntryId(long fragmentEntryId) { return findByFragmentEntryId( fragmentEntryId, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null); } /** * Returns a range of all the fragment entry links where fragmentEntryId = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param fragmentEntryId the fragment entry ID * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @return the range of matching fragment entry links */ @Override public List findByFragmentEntryId( long fragmentEntryId, int start, int end) { return findByFragmentEntryId(fragmentEntryId, start, end, null); } /** * Returns an ordered range of all the fragment entry links where fragmentEntryId = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param fragmentEntryId the fragment entry ID * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @return the ordered range of matching fragment entry links */ @Override public List findByFragmentEntryId( long fragmentEntryId, int start, int end, OrderByComparator orderByComparator) { return findByFragmentEntryId( fragmentEntryId, start, end, orderByComparator, true); } /** * Returns an ordered range of all the fragment entry links where fragmentEntryId = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param fragmentEntryId the fragment entry ID * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @param useFinderCache whether to use the finder cache * @return the ordered range of matching fragment entry links */ @Override public List findByFragmentEntryId( long fragmentEntryId, int start, int end, OrderByComparator orderByComparator, boolean useFinderCache) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { FinderPath finderPath = null; Object[] finderArgs = null; if ((start == QueryUtil.ALL_POS) && (end == QueryUtil.ALL_POS) && (orderByComparator == null)) { if (useFinderCache) { finderPath = _finderPathWithoutPaginationFindByFragmentEntryId; finderArgs = new Object[] {fragmentEntryId}; } } else if (useFinderCache) { finderPath = _finderPathWithPaginationFindByFragmentEntryId; finderArgs = new Object[] { fragmentEntryId, start, end, orderByComparator }; } List list = null; if (useFinderCache) { list = (List)finderCache.getResult( finderPath, finderArgs, this); if ((list != null) && !list.isEmpty()) { for (FragmentEntryLink fragmentEntryLink : list) { if (fragmentEntryId != fragmentEntryLink.getFragmentEntryId()) { list = null; break; } } } } if (list == null) { StringBundler sb = null; if (orderByComparator != null) { sb = new StringBundler( 3 + (orderByComparator.getOrderByFields().length * 2)); } else { sb = new StringBundler(3); } sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_FRAGMENTENTRYID_FRAGMENTENTRYID_2); if (orderByComparator != null) { appendOrderByComparator( sb, _ORDER_BY_ENTITY_ALIAS, orderByComparator); } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(fragmentEntryId); list = (List)QueryUtil.list( query, getDialect(), start, end); cacheResult(list); if (useFinderCache) { finderCache.putResult(finderPath, finderArgs, list); } } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return list; } } /** * Returns the first fragment entry link in the ordered set where fragmentEntryId = ?. * * @param fragmentEntryId the fragment entry ID * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByFragmentEntryId_First( long fragmentEntryId, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByFragmentEntryId_First( fragmentEntryId, orderByComparator); if (fragmentEntryLink != null) { return fragmentEntryLink; } StringBundler sb = new StringBundler(4); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("fragmentEntryId="); sb.append(fragmentEntryId); sb.append("}"); throw new NoSuchEntryLinkException(sb.toString()); } /** * Returns the first fragment entry link in the ordered set where fragmentEntryId = ?. * * @param fragmentEntryId the fragment entry ID * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByFragmentEntryId_First( long fragmentEntryId, OrderByComparator orderByComparator) { List list = findByFragmentEntryId( fragmentEntryId, 0, 1, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the last fragment entry link in the ordered set where fragmentEntryId = ?. * * @param fragmentEntryId the fragment entry ID * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByFragmentEntryId_Last( long fragmentEntryId, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByFragmentEntryId_Last( fragmentEntryId, orderByComparator); if (fragmentEntryLink != null) { return fragmentEntryLink; } StringBundler sb = new StringBundler(4); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("fragmentEntryId="); sb.append(fragmentEntryId); sb.append("}"); throw new NoSuchEntryLinkException(sb.toString()); } /** * Returns the last fragment entry link in the ordered set where fragmentEntryId = ?. * * @param fragmentEntryId the fragment entry ID * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByFragmentEntryId_Last( long fragmentEntryId, OrderByComparator orderByComparator) { int count = countByFragmentEntryId(fragmentEntryId); if (count == 0) { return null; } List list = findByFragmentEntryId( fragmentEntryId, count - 1, count, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the fragment entry links before and after the current fragment entry link in the ordered set where fragmentEntryId = ?. * * @param fragmentEntryLinkId the primary key of the current fragment entry link * @param fragmentEntryId the fragment entry ID * @param orderByComparator the comparator to order the set by (optionally null) * @return the previous, current, and next fragment entry link * @throws NoSuchEntryLinkException if a fragment entry link with the primary key could not be found */ @Override public FragmentEntryLink[] findByFragmentEntryId_PrevAndNext( long fragmentEntryLinkId, long fragmentEntryId, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = findByPrimaryKey( fragmentEntryLinkId); Session session = null; try { session = openSession(); FragmentEntryLink[] array = new FragmentEntryLinkImpl[3]; array[0] = getByFragmentEntryId_PrevAndNext( session, fragmentEntryLink, fragmentEntryId, orderByComparator, true); array[1] = fragmentEntryLink; array[2] = getByFragmentEntryId_PrevAndNext( session, fragmentEntryLink, fragmentEntryId, orderByComparator, false); return array; } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } protected FragmentEntryLink getByFragmentEntryId_PrevAndNext( Session session, FragmentEntryLink fragmentEntryLink, long fragmentEntryId, OrderByComparator orderByComparator, boolean previous) { StringBundler sb = null; if (orderByComparator != null) { sb = new StringBundler( 4 + (orderByComparator.getOrderByConditionFields().length * 3) + (orderByComparator.getOrderByFields().length * 3)); } else { sb = new StringBundler(3); } sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_FRAGMENTENTRYID_FRAGMENTENTRYID_2); if (orderByComparator != null) { String[] orderByConditionFields = orderByComparator.getOrderByConditionFields(); if (orderByConditionFields.length > 0) { sb.append(WHERE_AND); } for (int i = 0; i < orderByConditionFields.length; i++) { sb.append(_ORDER_BY_ENTITY_ALIAS); sb.append(orderByConditionFields[i]); if ((i + 1) < orderByConditionFields.length) { if (orderByComparator.isAscending() ^ previous) { sb.append(WHERE_GREATER_THAN_HAS_NEXT); } else { sb.append(WHERE_LESSER_THAN_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { sb.append(WHERE_GREATER_THAN); } else { sb.append(WHERE_LESSER_THAN); } } } sb.append(ORDER_BY_CLAUSE); String[] orderByFields = orderByComparator.getOrderByFields(); for (int i = 0; i < orderByFields.length; i++) { sb.append(_ORDER_BY_ENTITY_ALIAS); sb.append(orderByFields[i]); if ((i + 1) < orderByFields.length) { if (orderByComparator.isAscending() ^ previous) { sb.append(ORDER_BY_ASC_HAS_NEXT); } else { sb.append(ORDER_BY_DESC_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { sb.append(ORDER_BY_ASC); } else { sb.append(ORDER_BY_DESC); } } } } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Query query = session.createQuery(sql); query.setFirstResult(0); query.setMaxResults(2); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(fragmentEntryId); if (orderByComparator != null) { for (Object orderByConditionValue : orderByComparator.getOrderByConditionValues( fragmentEntryLink)) { queryPos.add(orderByConditionValue); } } List list = query.list(); if (list.size() == 2) { return list.get(1); } else { return null; } } /** * Returns all the fragment entry links where fragmentEntryId = any ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param fragmentEntryIds the fragment entry IDs * @return the matching fragment entry links */ @Override public List findByFragmentEntryId( long[] fragmentEntryIds) { return findByFragmentEntryId( fragmentEntryIds, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null); } /** * Returns a range of all the fragment entry links where fragmentEntryId = any ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param fragmentEntryIds the fragment entry IDs * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @return the range of matching fragment entry links */ @Override public List findByFragmentEntryId( long[] fragmentEntryIds, int start, int end) { return findByFragmentEntryId(fragmentEntryIds, start, end, null); } /** * Returns an ordered range of all the fragment entry links where fragmentEntryId = any ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param fragmentEntryIds the fragment entry IDs * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @return the ordered range of matching fragment entry links */ @Override public List findByFragmentEntryId( long[] fragmentEntryIds, int start, int end, OrderByComparator orderByComparator) { return findByFragmentEntryId( fragmentEntryIds, start, end, orderByComparator, true); } /** * Returns an ordered range of all the fragment entry links where fragmentEntryId = ?, optionally using the finder cache. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param fragmentEntryIds the fragment entry IDs * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @param useFinderCache whether to use the finder cache * @return the ordered range of matching fragment entry links */ @Override public List findByFragmentEntryId( long[] fragmentEntryIds, int start, int end, OrderByComparator orderByComparator, boolean useFinderCache) { if (fragmentEntryIds == null) { fragmentEntryIds = new long[0]; } else if (fragmentEntryIds.length > 1) { fragmentEntryIds = ArrayUtil.sortedUnique(fragmentEntryIds); } if (fragmentEntryIds.length == 1) { return findByFragmentEntryId( fragmentEntryIds[0], start, end, orderByComparator); } try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { Object[] finderArgs = null; if ((start == QueryUtil.ALL_POS) && (end == QueryUtil.ALL_POS) && (orderByComparator == null)) { if (useFinderCache) { finderArgs = new Object[] { StringUtil.merge(fragmentEntryIds) }; } } else if (useFinderCache) { finderArgs = new Object[] { StringUtil.merge(fragmentEntryIds), start, end, orderByComparator }; } List list = null; if (useFinderCache) { list = (List)finderCache.getResult( _finderPathWithPaginationFindByFragmentEntryId, finderArgs, this); if ((list != null) && !list.isEmpty()) { for (FragmentEntryLink fragmentEntryLink : list) { if (!ArrayUtil.contains( fragmentEntryIds, fragmentEntryLink.getFragmentEntryId())) { list = null; break; } } } } if (list == null) { StringBundler sb = new StringBundler(); sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); if (fragmentEntryIds.length > 0) { sb.append("("); sb.append(_FINDER_COLUMN_FRAGMENTENTRYID_FRAGMENTENTRYID_7); sb.append(StringUtil.merge(fragmentEntryIds)); sb.append(")"); sb.append(")"); } sb.setStringAt( removeConjunction(sb.stringAt(sb.index() - 1)), sb.index() - 1); if (orderByComparator != null) { appendOrderByComparator( sb, _ORDER_BY_ENTITY_ALIAS, orderByComparator); } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); list = (List)QueryUtil.list( query, getDialect(), start, end); cacheResult(list); if (useFinderCache) { finderCache.putResult( _finderPathWithPaginationFindByFragmentEntryId, finderArgs, list); } } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return list; } } /** * Removes all the fragment entry links where fragmentEntryId = ? from the database. * * @param fragmentEntryId the fragment entry ID */ @Override public void removeByFragmentEntryId(long fragmentEntryId) { for (FragmentEntryLink fragmentEntryLink : findByFragmentEntryId( fragmentEntryId, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null)) { remove(fragmentEntryLink); } } /** * Returns the number of fragment entry links where fragmentEntryId = ?. * * @param fragmentEntryId the fragment entry ID * @return the number of matching fragment entry links */ @Override public int countByFragmentEntryId(long fragmentEntryId) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { FinderPath finderPath = _finderPathCountByFragmentEntryId; Object[] finderArgs = new Object[] {fragmentEntryId}; Long count = (Long)finderCache.getResult( finderPath, finderArgs, this); if (count == null) { StringBundler sb = new StringBundler(2); sb.append(_SQL_COUNT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_FRAGMENTENTRYID_FRAGMENTENTRYID_2); String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(fragmentEntryId); count = (Long)query.uniqueResult(); finderCache.putResult(finderPath, finderArgs, count); } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return count.intValue(); } } /** * Returns the number of fragment entry links where fragmentEntryId = any ?. * * @param fragmentEntryIds the fragment entry IDs * @return the number of matching fragment entry links */ @Override public int countByFragmentEntryId(long[] fragmentEntryIds) { if (fragmentEntryIds == null) { fragmentEntryIds = new long[0]; } else if (fragmentEntryIds.length > 1) { fragmentEntryIds = ArrayUtil.sortedUnique(fragmentEntryIds); } try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { Object[] finderArgs = new Object[] { StringUtil.merge(fragmentEntryIds) }; Long count = (Long)finderCache.getResult( _finderPathWithPaginationCountByFragmentEntryId, finderArgs, this); if (count == null) { StringBundler sb = new StringBundler(); sb.append(_SQL_COUNT_FRAGMENTENTRYLINK_WHERE); if (fragmentEntryIds.length > 0) { sb.append("("); sb.append(_FINDER_COLUMN_FRAGMENTENTRYID_FRAGMENTENTRYID_7); sb.append(StringUtil.merge(fragmentEntryIds)); sb.append(")"); sb.append(")"); } sb.setStringAt( removeConjunction(sb.stringAt(sb.index() - 1)), sb.index() - 1); String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); count = (Long)query.uniqueResult(); finderCache.putResult( _finderPathWithPaginationCountByFragmentEntryId, finderArgs, count); } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return count.intValue(); } } private static final String _FINDER_COLUMN_FRAGMENTENTRYID_FRAGMENTENTRYID_2 = "fragmentEntryLink.fragmentEntryId = ?"; private static final String _FINDER_COLUMN_FRAGMENTENTRYID_FRAGMENTENTRYID_7 = "fragmentEntryLink.fragmentEntryId IN ("; private FinderPath _finderPathWithPaginationFindByRendererKey; private FinderPath _finderPathWithoutPaginationFindByRendererKey; private FinderPath _finderPathCountByRendererKey; /** * Returns all the fragment entry links where rendererKey = ?. * * @param rendererKey the renderer key * @return the matching fragment entry links */ @Override public List findByRendererKey(String rendererKey) { return findByRendererKey( rendererKey, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null); } /** * Returns a range of all the fragment entry links where rendererKey = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param rendererKey the renderer key * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @return the range of matching fragment entry links */ @Override public List findByRendererKey( String rendererKey, int start, int end) { return findByRendererKey(rendererKey, start, end, null); } /** * Returns an ordered range of all the fragment entry links where rendererKey = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param rendererKey the renderer key * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @return the ordered range of matching fragment entry links */ @Override public List findByRendererKey( String rendererKey, int start, int end, OrderByComparator orderByComparator) { return findByRendererKey( rendererKey, start, end, orderByComparator, true); } /** * Returns an ordered range of all the fragment entry links where rendererKey = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param rendererKey the renderer key * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @param useFinderCache whether to use the finder cache * @return the ordered range of matching fragment entry links */ @Override public List findByRendererKey( String rendererKey, int start, int end, OrderByComparator orderByComparator, boolean useFinderCache) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { rendererKey = Objects.toString(rendererKey, ""); FinderPath finderPath = null; Object[] finderArgs = null; if ((start == QueryUtil.ALL_POS) && (end == QueryUtil.ALL_POS) && (orderByComparator == null)) { if (useFinderCache) { finderPath = _finderPathWithoutPaginationFindByRendererKey; finderArgs = new Object[] {rendererKey}; } } else if (useFinderCache) { finderPath = _finderPathWithPaginationFindByRendererKey; finderArgs = new Object[] { rendererKey, start, end, orderByComparator }; } List list = null; if (useFinderCache) { list = (List)finderCache.getResult( finderPath, finderArgs, this); if ((list != null) && !list.isEmpty()) { for (FragmentEntryLink fragmentEntryLink : list) { if (!rendererKey.equals( fragmentEntryLink.getRendererKey())) { list = null; break; } } } } if (list == null) { StringBundler sb = null; if (orderByComparator != null) { sb = new StringBundler( 3 + (orderByComparator.getOrderByFields().length * 2)); } else { sb = new StringBundler(3); } sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); boolean bindRendererKey = false; if (rendererKey.isEmpty()) { sb.append(_FINDER_COLUMN_RENDERERKEY_RENDERERKEY_3); } else { bindRendererKey = true; sb.append(_FINDER_COLUMN_RENDERERKEY_RENDERERKEY_2); } if (orderByComparator != null) { appendOrderByComparator( sb, _ORDER_BY_ENTITY_ALIAS, orderByComparator); } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); if (bindRendererKey) { queryPos.add(rendererKey); } list = (List)QueryUtil.list( query, getDialect(), start, end); cacheResult(list); if (useFinderCache) { finderCache.putResult(finderPath, finderArgs, list); } } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return list; } } /** * Returns the first fragment entry link in the ordered set where rendererKey = ?. * * @param rendererKey the renderer key * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByRendererKey_First( String rendererKey, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByRendererKey_First( rendererKey, orderByComparator); if (fragmentEntryLink != null) { return fragmentEntryLink; } StringBundler sb = new StringBundler(4); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("rendererKey="); sb.append(rendererKey); sb.append("}"); throw new NoSuchEntryLinkException(sb.toString()); } /** * Returns the first fragment entry link in the ordered set where rendererKey = ?. * * @param rendererKey the renderer key * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByRendererKey_First( String rendererKey, OrderByComparator orderByComparator) { List list = findByRendererKey( rendererKey, 0, 1, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the last fragment entry link in the ordered set where rendererKey = ?. * * @param rendererKey the renderer key * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByRendererKey_Last( String rendererKey, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByRendererKey_Last( rendererKey, orderByComparator); if (fragmentEntryLink != null) { return fragmentEntryLink; } StringBundler sb = new StringBundler(4); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("rendererKey="); sb.append(rendererKey); sb.append("}"); throw new NoSuchEntryLinkException(sb.toString()); } /** * Returns the last fragment entry link in the ordered set where rendererKey = ?. * * @param rendererKey the renderer key * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByRendererKey_Last( String rendererKey, OrderByComparator orderByComparator) { int count = countByRendererKey(rendererKey); if (count == 0) { return null; } List list = findByRendererKey( rendererKey, count - 1, count, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the fragment entry links before and after the current fragment entry link in the ordered set where rendererKey = ?. * * @param fragmentEntryLinkId the primary key of the current fragment entry link * @param rendererKey the renderer key * @param orderByComparator the comparator to order the set by (optionally null) * @return the previous, current, and next fragment entry link * @throws NoSuchEntryLinkException if a fragment entry link with the primary key could not be found */ @Override public FragmentEntryLink[] findByRendererKey_PrevAndNext( long fragmentEntryLinkId, String rendererKey, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { rendererKey = Objects.toString(rendererKey, ""); FragmentEntryLink fragmentEntryLink = findByPrimaryKey( fragmentEntryLinkId); Session session = null; try { session = openSession(); FragmentEntryLink[] array = new FragmentEntryLinkImpl[3]; array[0] = getByRendererKey_PrevAndNext( session, fragmentEntryLink, rendererKey, orderByComparator, true); array[1] = fragmentEntryLink; array[2] = getByRendererKey_PrevAndNext( session, fragmentEntryLink, rendererKey, orderByComparator, false); return array; } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } protected FragmentEntryLink getByRendererKey_PrevAndNext( Session session, FragmentEntryLink fragmentEntryLink, String rendererKey, OrderByComparator orderByComparator, boolean previous) { StringBundler sb = null; if (orderByComparator != null) { sb = new StringBundler( 4 + (orderByComparator.getOrderByConditionFields().length * 3) + (orderByComparator.getOrderByFields().length * 3)); } else { sb = new StringBundler(3); } sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); boolean bindRendererKey = false; if (rendererKey.isEmpty()) { sb.append(_FINDER_COLUMN_RENDERERKEY_RENDERERKEY_3); } else { bindRendererKey = true; sb.append(_FINDER_COLUMN_RENDERERKEY_RENDERERKEY_2); } if (orderByComparator != null) { String[] orderByConditionFields = orderByComparator.getOrderByConditionFields(); if (orderByConditionFields.length > 0) { sb.append(WHERE_AND); } for (int i = 0; i < orderByConditionFields.length; i++) { sb.append(_ORDER_BY_ENTITY_ALIAS); sb.append(orderByConditionFields[i]); if ((i + 1) < orderByConditionFields.length) { if (orderByComparator.isAscending() ^ previous) { sb.append(WHERE_GREATER_THAN_HAS_NEXT); } else { sb.append(WHERE_LESSER_THAN_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { sb.append(WHERE_GREATER_THAN); } else { sb.append(WHERE_LESSER_THAN); } } } sb.append(ORDER_BY_CLAUSE); String[] orderByFields = orderByComparator.getOrderByFields(); for (int i = 0; i < orderByFields.length; i++) { sb.append(_ORDER_BY_ENTITY_ALIAS); sb.append(orderByFields[i]); if ((i + 1) < orderByFields.length) { if (orderByComparator.isAscending() ^ previous) { sb.append(ORDER_BY_ASC_HAS_NEXT); } else { sb.append(ORDER_BY_DESC_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { sb.append(ORDER_BY_ASC); } else { sb.append(ORDER_BY_DESC); } } } } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Query query = session.createQuery(sql); query.setFirstResult(0); query.setMaxResults(2); QueryPos queryPos = QueryPos.getInstance(query); if (bindRendererKey) { queryPos.add(rendererKey); } if (orderByComparator != null) { for (Object orderByConditionValue : orderByComparator.getOrderByConditionValues( fragmentEntryLink)) { queryPos.add(orderByConditionValue); } } List list = query.list(); if (list.size() == 2) { return list.get(1); } else { return null; } } /** * Removes all the fragment entry links where rendererKey = ? from the database. * * @param rendererKey the renderer key */ @Override public void removeByRendererKey(String rendererKey) { for (FragmentEntryLink fragmentEntryLink : findByRendererKey( rendererKey, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null)) { remove(fragmentEntryLink); } } /** * Returns the number of fragment entry links where rendererKey = ?. * * @param rendererKey the renderer key * @return the number of matching fragment entry links */ @Override public int countByRendererKey(String rendererKey) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { rendererKey = Objects.toString(rendererKey, ""); FinderPath finderPath = _finderPathCountByRendererKey; Object[] finderArgs = new Object[] {rendererKey}; Long count = (Long)finderCache.getResult( finderPath, finderArgs, this); if (count == null) { StringBundler sb = new StringBundler(2); sb.append(_SQL_COUNT_FRAGMENTENTRYLINK_WHERE); boolean bindRendererKey = false; if (rendererKey.isEmpty()) { sb.append(_FINDER_COLUMN_RENDERERKEY_RENDERERKEY_3); } else { bindRendererKey = true; sb.append(_FINDER_COLUMN_RENDERERKEY_RENDERERKEY_2); } String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); if (bindRendererKey) { queryPos.add(rendererKey); } count = (Long)query.uniqueResult(); finderCache.putResult(finderPath, finderArgs, count); } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return count.intValue(); } } private static final String _FINDER_COLUMN_RENDERERKEY_RENDERERKEY_2 = "fragmentEntryLink.rendererKey = ?"; private static final String _FINDER_COLUMN_RENDERERKEY_RENDERERKEY_3 = "(fragmentEntryLink.rendererKey IS NULL OR fragmentEntryLink.rendererKey = '')"; private FinderPath _finderPathWithPaginationFindByG_F; private FinderPath _finderPathWithoutPaginationFindByG_F; private FinderPath _finderPathCountByG_F; /** * Returns all the fragment entry links where groupId = ? and fragmentEntryId = ?. * * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @return the matching fragment entry links */ @Override public List findByG_F( long groupId, long fragmentEntryId) { return findByG_F( groupId, fragmentEntryId, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null); } /** * Returns a range of all the fragment entry links where groupId = ? and fragmentEntryId = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @return the range of matching fragment entry links */ @Override public List findByG_F( long groupId, long fragmentEntryId, int start, int end) { return findByG_F(groupId, fragmentEntryId, start, end, null); } /** * Returns an ordered range of all the fragment entry links where groupId = ? and fragmentEntryId = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @return the ordered range of matching fragment entry links */ @Override public List findByG_F( long groupId, long fragmentEntryId, int start, int end, OrderByComparator orderByComparator) { return findByG_F( groupId, fragmentEntryId, start, end, orderByComparator, true); } /** * Returns an ordered range of all the fragment entry links where groupId = ? and fragmentEntryId = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @param useFinderCache whether to use the finder cache * @return the ordered range of matching fragment entry links */ @Override public List findByG_F( long groupId, long fragmentEntryId, int start, int end, OrderByComparator orderByComparator, boolean useFinderCache) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { FinderPath finderPath = null; Object[] finderArgs = null; if ((start == QueryUtil.ALL_POS) && (end == QueryUtil.ALL_POS) && (orderByComparator == null)) { if (useFinderCache) { finderPath = _finderPathWithoutPaginationFindByG_F; finderArgs = new Object[] {groupId, fragmentEntryId}; } } else if (useFinderCache) { finderPath = _finderPathWithPaginationFindByG_F; finderArgs = new Object[] { groupId, fragmentEntryId, start, end, orderByComparator }; } List list = null; if (useFinderCache) { list = (List)finderCache.getResult( finderPath, finderArgs, this); if ((list != null) && !list.isEmpty()) { for (FragmentEntryLink fragmentEntryLink : list) { if ((groupId != fragmentEntryLink.getGroupId()) || (fragmentEntryId != fragmentEntryLink.getFragmentEntryId())) { list = null; break; } } } } if (list == null) { StringBundler sb = null; if (orderByComparator != null) { sb = new StringBundler( 4 + (orderByComparator.getOrderByFields().length * 2)); } else { sb = new StringBundler(4); } sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_F_GROUPID_2); sb.append(_FINDER_COLUMN_G_F_FRAGMENTENTRYID_2); if (orderByComparator != null) { appendOrderByComparator( sb, _ORDER_BY_ENTITY_ALIAS, orderByComparator); } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(fragmentEntryId); list = (List)QueryUtil.list( query, getDialect(), start, end); cacheResult(list); if (useFinderCache) { finderCache.putResult(finderPath, finderArgs, list); } } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return list; } } /** * Returns the first fragment entry link in the ordered set where groupId = ? and fragmentEntryId = ?. * * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByG_F_First( long groupId, long fragmentEntryId, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByG_F_First( groupId, fragmentEntryId, orderByComparator); if (fragmentEntryLink != null) { return fragmentEntryLink; } StringBundler sb = new StringBundler(6); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("groupId="); sb.append(groupId); sb.append(", fragmentEntryId="); sb.append(fragmentEntryId); sb.append("}"); throw new NoSuchEntryLinkException(sb.toString()); } /** * Returns the first fragment entry link in the ordered set where groupId = ? and fragmentEntryId = ?. * * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByG_F_First( long groupId, long fragmentEntryId, OrderByComparator orderByComparator) { List list = findByG_F( groupId, fragmentEntryId, 0, 1, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the last fragment entry link in the ordered set where groupId = ? and fragmentEntryId = ?. * * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByG_F_Last( long groupId, long fragmentEntryId, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByG_F_Last( groupId, fragmentEntryId, orderByComparator); if (fragmentEntryLink != null) { return fragmentEntryLink; } StringBundler sb = new StringBundler(6); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("groupId="); sb.append(groupId); sb.append(", fragmentEntryId="); sb.append(fragmentEntryId); sb.append("}"); throw new NoSuchEntryLinkException(sb.toString()); } /** * Returns the last fragment entry link in the ordered set where groupId = ? and fragmentEntryId = ?. * * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByG_F_Last( long groupId, long fragmentEntryId, OrderByComparator orderByComparator) { int count = countByG_F(groupId, fragmentEntryId); if (count == 0) { return null; } List list = findByG_F( groupId, fragmentEntryId, count - 1, count, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the fragment entry links before and after the current fragment entry link in the ordered set where groupId = ? and fragmentEntryId = ?. * * @param fragmentEntryLinkId the primary key of the current fragment entry link * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param orderByComparator the comparator to order the set by (optionally null) * @return the previous, current, and next fragment entry link * @throws NoSuchEntryLinkException if a fragment entry link with the primary key could not be found */ @Override public FragmentEntryLink[] findByG_F_PrevAndNext( long fragmentEntryLinkId, long groupId, long fragmentEntryId, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = findByPrimaryKey( fragmentEntryLinkId); Session session = null; try { session = openSession(); FragmentEntryLink[] array = new FragmentEntryLinkImpl[3]; array[0] = getByG_F_PrevAndNext( session, fragmentEntryLink, groupId, fragmentEntryId, orderByComparator, true); array[1] = fragmentEntryLink; array[2] = getByG_F_PrevAndNext( session, fragmentEntryLink, groupId, fragmentEntryId, orderByComparator, false); return array; } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } protected FragmentEntryLink getByG_F_PrevAndNext( Session session, FragmentEntryLink fragmentEntryLink, long groupId, long fragmentEntryId, OrderByComparator orderByComparator, boolean previous) { StringBundler sb = null; if (orderByComparator != null) { sb = new StringBundler( 5 + (orderByComparator.getOrderByConditionFields().length * 3) + (orderByComparator.getOrderByFields().length * 3)); } else { sb = new StringBundler(4); } sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_F_GROUPID_2); sb.append(_FINDER_COLUMN_G_F_FRAGMENTENTRYID_2); if (orderByComparator != null) { String[] orderByConditionFields = orderByComparator.getOrderByConditionFields(); if (orderByConditionFields.length > 0) { sb.append(WHERE_AND); } for (int i = 0; i < orderByConditionFields.length; i++) { sb.append(_ORDER_BY_ENTITY_ALIAS); sb.append(orderByConditionFields[i]); if ((i + 1) < orderByConditionFields.length) { if (orderByComparator.isAscending() ^ previous) { sb.append(WHERE_GREATER_THAN_HAS_NEXT); } else { sb.append(WHERE_LESSER_THAN_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { sb.append(WHERE_GREATER_THAN); } else { sb.append(WHERE_LESSER_THAN); } } } sb.append(ORDER_BY_CLAUSE); String[] orderByFields = orderByComparator.getOrderByFields(); for (int i = 0; i < orderByFields.length; i++) { sb.append(_ORDER_BY_ENTITY_ALIAS); sb.append(orderByFields[i]); if ((i + 1) < orderByFields.length) { if (orderByComparator.isAscending() ^ previous) { sb.append(ORDER_BY_ASC_HAS_NEXT); } else { sb.append(ORDER_BY_DESC_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { sb.append(ORDER_BY_ASC); } else { sb.append(ORDER_BY_DESC); } } } } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Query query = session.createQuery(sql); query.setFirstResult(0); query.setMaxResults(2); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(fragmentEntryId); if (orderByComparator != null) { for (Object orderByConditionValue : orderByComparator.getOrderByConditionValues( fragmentEntryLink)) { queryPos.add(orderByConditionValue); } } List list = query.list(); if (list.size() == 2) { return list.get(1); } else { return null; } } /** * Removes all the fragment entry links where groupId = ? and fragmentEntryId = ? from the database. * * @param groupId the group ID * @param fragmentEntryId the fragment entry ID */ @Override public void removeByG_F(long groupId, long fragmentEntryId) { for (FragmentEntryLink fragmentEntryLink : findByG_F( groupId, fragmentEntryId, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null)) { remove(fragmentEntryLink); } } /** * Returns the number of fragment entry links where groupId = ? and fragmentEntryId = ?. * * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @return the number of matching fragment entry links */ @Override public int countByG_F(long groupId, long fragmentEntryId) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { FinderPath finderPath = _finderPathCountByG_F; Object[] finderArgs = new Object[] {groupId, fragmentEntryId}; Long count = (Long)finderCache.getResult( finderPath, finderArgs, this); if (count == null) { StringBundler sb = new StringBundler(3); sb.append(_SQL_COUNT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_F_GROUPID_2); sb.append(_FINDER_COLUMN_G_F_FRAGMENTENTRYID_2); String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(fragmentEntryId); count = (Long)query.uniqueResult(); finderCache.putResult(finderPath, finderArgs, count); } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return count.intValue(); } } private static final String _FINDER_COLUMN_G_F_GROUPID_2 = "fragmentEntryLink.groupId = ? AND "; private static final String _FINDER_COLUMN_G_F_FRAGMENTENTRYID_2 = "fragmentEntryLink.fragmentEntryId = ?"; private FinderPath _finderPathWithPaginationFindByG_P; private FinderPath _finderPathWithoutPaginationFindByG_P; private FinderPath _finderPathCountByG_P; /** * Returns all the fragment entry links where groupId = ? and plid = ?. * * @param groupId the group ID * @param plid the plid * @return the matching fragment entry links */ @Override public List findByG_P(long groupId, long plid) { return findByG_P( groupId, plid, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null); } /** * Returns a range of all the fragment entry links where groupId = ? and plid = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param plid the plid * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @return the range of matching fragment entry links */ @Override public List findByG_P( long groupId, long plid, int start, int end) { return findByG_P(groupId, plid, start, end, null); } /** * Returns an ordered range of all the fragment entry links where groupId = ? and plid = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param plid the plid * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @return the ordered range of matching fragment entry links */ @Override public List findByG_P( long groupId, long plid, int start, int end, OrderByComparator orderByComparator) { return findByG_P(groupId, plid, start, end, orderByComparator, true); } /** * Returns an ordered range of all the fragment entry links where groupId = ? and plid = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param plid the plid * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @param useFinderCache whether to use the finder cache * @return the ordered range of matching fragment entry links */ @Override public List findByG_P( long groupId, long plid, int start, int end, OrderByComparator orderByComparator, boolean useFinderCache) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { FinderPath finderPath = null; Object[] finderArgs = null; if ((start == QueryUtil.ALL_POS) && (end == QueryUtil.ALL_POS) && (orderByComparator == null)) { if (useFinderCache) { finderPath = _finderPathWithoutPaginationFindByG_P; finderArgs = new Object[] {groupId, plid}; } } else if (useFinderCache) { finderPath = _finderPathWithPaginationFindByG_P; finderArgs = new Object[] { groupId, plid, start, end, orderByComparator }; } List list = null; if (useFinderCache) { list = (List)finderCache.getResult( finderPath, finderArgs, this); if ((list != null) && !list.isEmpty()) { for (FragmentEntryLink fragmentEntryLink : list) { if ((groupId != fragmentEntryLink.getGroupId()) || (plid != fragmentEntryLink.getPlid())) { list = null; break; } } } } if (list == null) { StringBundler sb = null; if (orderByComparator != null) { sb = new StringBundler( 4 + (orderByComparator.getOrderByFields().length * 2)); } else { sb = new StringBundler(4); } sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_P_GROUPID_2); sb.append(_FINDER_COLUMN_G_P_PLID_2); if (orderByComparator != null) { appendOrderByComparator( sb, _ORDER_BY_ENTITY_ALIAS, orderByComparator); } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(plid); list = (List)QueryUtil.list( query, getDialect(), start, end); cacheResult(list); if (useFinderCache) { finderCache.putResult(finderPath, finderArgs, list); } } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return list; } } /** * Returns the first fragment entry link in the ordered set where groupId = ? and plid = ?. * * @param groupId the group ID * @param plid the plid * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByG_P_First( long groupId, long plid, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByG_P_First( groupId, plid, orderByComparator); if (fragmentEntryLink != null) { return fragmentEntryLink; } StringBundler sb = new StringBundler(6); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("groupId="); sb.append(groupId); sb.append(", plid="); sb.append(plid); sb.append("}"); throw new NoSuchEntryLinkException(sb.toString()); } /** * Returns the first fragment entry link in the ordered set where groupId = ? and plid = ?. * * @param groupId the group ID * @param plid the plid * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByG_P_First( long groupId, long plid, OrderByComparator orderByComparator) { List list = findByG_P( groupId, plid, 0, 1, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the last fragment entry link in the ordered set where groupId = ? and plid = ?. * * @param groupId the group ID * @param plid the plid * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByG_P_Last( long groupId, long plid, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByG_P_Last( groupId, plid, orderByComparator); if (fragmentEntryLink != null) { return fragmentEntryLink; } StringBundler sb = new StringBundler(6); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("groupId="); sb.append(groupId); sb.append(", plid="); sb.append(plid); sb.append("}"); throw new NoSuchEntryLinkException(sb.toString()); } /** * Returns the last fragment entry link in the ordered set where groupId = ? and plid = ?. * * @param groupId the group ID * @param plid the plid * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByG_P_Last( long groupId, long plid, OrderByComparator orderByComparator) { int count = countByG_P(groupId, plid); if (count == 0) { return null; } List list = findByG_P( groupId, plid, count - 1, count, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the fragment entry links before and after the current fragment entry link in the ordered set where groupId = ? and plid = ?. * * @param fragmentEntryLinkId the primary key of the current fragment entry link * @param groupId the group ID * @param plid the plid * @param orderByComparator the comparator to order the set by (optionally null) * @return the previous, current, and next fragment entry link * @throws NoSuchEntryLinkException if a fragment entry link with the primary key could not be found */ @Override public FragmentEntryLink[] findByG_P_PrevAndNext( long fragmentEntryLinkId, long groupId, long plid, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = findByPrimaryKey( fragmentEntryLinkId); Session session = null; try { session = openSession(); FragmentEntryLink[] array = new FragmentEntryLinkImpl[3]; array[0] = getByG_P_PrevAndNext( session, fragmentEntryLink, groupId, plid, orderByComparator, true); array[1] = fragmentEntryLink; array[2] = getByG_P_PrevAndNext( session, fragmentEntryLink, groupId, plid, orderByComparator, false); return array; } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } protected FragmentEntryLink getByG_P_PrevAndNext( Session session, FragmentEntryLink fragmentEntryLink, long groupId, long plid, OrderByComparator orderByComparator, boolean previous) { StringBundler sb = null; if (orderByComparator != null) { sb = new StringBundler( 5 + (orderByComparator.getOrderByConditionFields().length * 3) + (orderByComparator.getOrderByFields().length * 3)); } else { sb = new StringBundler(4); } sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_P_GROUPID_2); sb.append(_FINDER_COLUMN_G_P_PLID_2); if (orderByComparator != null) { String[] orderByConditionFields = orderByComparator.getOrderByConditionFields(); if (orderByConditionFields.length > 0) { sb.append(WHERE_AND); } for (int i = 0; i < orderByConditionFields.length; i++) { sb.append(_ORDER_BY_ENTITY_ALIAS); sb.append(orderByConditionFields[i]); if ((i + 1) < orderByConditionFields.length) { if (orderByComparator.isAscending() ^ previous) { sb.append(WHERE_GREATER_THAN_HAS_NEXT); } else { sb.append(WHERE_LESSER_THAN_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { sb.append(WHERE_GREATER_THAN); } else { sb.append(WHERE_LESSER_THAN); } } } sb.append(ORDER_BY_CLAUSE); String[] orderByFields = orderByComparator.getOrderByFields(); for (int i = 0; i < orderByFields.length; i++) { sb.append(_ORDER_BY_ENTITY_ALIAS); sb.append(orderByFields[i]); if ((i + 1) < orderByFields.length) { if (orderByComparator.isAscending() ^ previous) { sb.append(ORDER_BY_ASC_HAS_NEXT); } else { sb.append(ORDER_BY_DESC_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { sb.append(ORDER_BY_ASC); } else { sb.append(ORDER_BY_DESC); } } } } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Query query = session.createQuery(sql); query.setFirstResult(0); query.setMaxResults(2); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(plid); if (orderByComparator != null) { for (Object orderByConditionValue : orderByComparator.getOrderByConditionValues( fragmentEntryLink)) { queryPos.add(orderByConditionValue); } } List list = query.list(); if (list.size() == 2) { return list.get(1); } else { return null; } } /** * Removes all the fragment entry links where groupId = ? and plid = ? from the database. * * @param groupId the group ID * @param plid the plid */ @Override public void removeByG_P(long groupId, long plid) { for (FragmentEntryLink fragmentEntryLink : findByG_P( groupId, plid, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null)) { remove(fragmentEntryLink); } } /** * Returns the number of fragment entry links where groupId = ? and plid = ?. * * @param groupId the group ID * @param plid the plid * @return the number of matching fragment entry links */ @Override public int countByG_P(long groupId, long plid) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { FinderPath finderPath = _finderPathCountByG_P; Object[] finderArgs = new Object[] {groupId, plid}; Long count = (Long)finderCache.getResult( finderPath, finderArgs, this); if (count == null) { StringBundler sb = new StringBundler(3); sb.append(_SQL_COUNT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_P_GROUPID_2); sb.append(_FINDER_COLUMN_G_P_PLID_2); String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(plid); count = (Long)query.uniqueResult(); finderCache.putResult(finderPath, finderArgs, count); } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return count.intValue(); } } private static final String _FINDER_COLUMN_G_P_GROUPID_2 = "fragmentEntryLink.groupId = ? AND "; private static final String _FINDER_COLUMN_G_P_PLID_2 = "fragmentEntryLink.plid = ?"; private FinderPath _finderPathWithPaginationFindByC_R; private FinderPath _finderPathWithoutPaginationFindByC_R; private FinderPath _finderPathCountByC_R; private FinderPath _finderPathWithPaginationCountByC_R; /** * Returns all the fragment entry links where companyId = ? and rendererKey = ?. * * @param companyId the company ID * @param rendererKey the renderer key * @return the matching fragment entry links */ @Override public List findByC_R( long companyId, String rendererKey) { return findByC_R( companyId, rendererKey, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null); } /** * Returns a range of all the fragment entry links where companyId = ? and rendererKey = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param companyId the company ID * @param rendererKey the renderer key * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @return the range of matching fragment entry links */ @Override public List findByC_R( long companyId, String rendererKey, int start, int end) { return findByC_R(companyId, rendererKey, start, end, null); } /** * Returns an ordered range of all the fragment entry links where companyId = ? and rendererKey = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param companyId the company ID * @param rendererKey the renderer key * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @return the ordered range of matching fragment entry links */ @Override public List findByC_R( long companyId, String rendererKey, int start, int end, OrderByComparator orderByComparator) { return findByC_R( companyId, rendererKey, start, end, orderByComparator, true); } /** * Returns an ordered range of all the fragment entry links where companyId = ? and rendererKey = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param companyId the company ID * @param rendererKey the renderer key * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @param useFinderCache whether to use the finder cache * @return the ordered range of matching fragment entry links */ @Override public List findByC_R( long companyId, String rendererKey, int start, int end, OrderByComparator orderByComparator, boolean useFinderCache) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { rendererKey = Objects.toString(rendererKey, ""); FinderPath finderPath = null; Object[] finderArgs = null; if ((start == QueryUtil.ALL_POS) && (end == QueryUtil.ALL_POS) && (orderByComparator == null)) { if (useFinderCache) { finderPath = _finderPathWithoutPaginationFindByC_R; finderArgs = new Object[] {companyId, rendererKey}; } } else if (useFinderCache) { finderPath = _finderPathWithPaginationFindByC_R; finderArgs = new Object[] { companyId, rendererKey, start, end, orderByComparator }; } List list = null; if (useFinderCache) { list = (List)finderCache.getResult( finderPath, finderArgs, this); if ((list != null) && !list.isEmpty()) { for (FragmentEntryLink fragmentEntryLink : list) { if ((companyId != fragmentEntryLink.getCompanyId()) || !rendererKey.equals( fragmentEntryLink.getRendererKey())) { list = null; break; } } } } if (list == null) { StringBundler sb = null; if (orderByComparator != null) { sb = new StringBundler( 4 + (orderByComparator.getOrderByFields().length * 2)); } else { sb = new StringBundler(4); } sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_C_R_COMPANYID_2); boolean bindRendererKey = false; if (rendererKey.isEmpty()) { sb.append(_FINDER_COLUMN_C_R_RENDERERKEY_3); } else { bindRendererKey = true; sb.append(_FINDER_COLUMN_C_R_RENDERERKEY_2); } if (orderByComparator != null) { appendOrderByComparator( sb, _ORDER_BY_ENTITY_ALIAS, orderByComparator); } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(companyId); if (bindRendererKey) { queryPos.add(rendererKey); } list = (List)QueryUtil.list( query, getDialect(), start, end); cacheResult(list); if (useFinderCache) { finderCache.putResult(finderPath, finderArgs, list); } } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return list; } } /** * Returns the first fragment entry link in the ordered set where companyId = ? and rendererKey = ?. * * @param companyId the company ID * @param rendererKey the renderer key * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByC_R_First( long companyId, String rendererKey, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByC_R_First( companyId, rendererKey, orderByComparator); if (fragmentEntryLink != null) { return fragmentEntryLink; } StringBundler sb = new StringBundler(6); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("companyId="); sb.append(companyId); sb.append(", rendererKey="); sb.append(rendererKey); sb.append("}"); throw new NoSuchEntryLinkException(sb.toString()); } /** * Returns the first fragment entry link in the ordered set where companyId = ? and rendererKey = ?. * * @param companyId the company ID * @param rendererKey the renderer key * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByC_R_First( long companyId, String rendererKey, OrderByComparator orderByComparator) { List list = findByC_R( companyId, rendererKey, 0, 1, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the last fragment entry link in the ordered set where companyId = ? and rendererKey = ?. * * @param companyId the company ID * @param rendererKey the renderer key * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByC_R_Last( long companyId, String rendererKey, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByC_R_Last( companyId, rendererKey, orderByComparator); if (fragmentEntryLink != null) { return fragmentEntryLink; } StringBundler sb = new StringBundler(6); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("companyId="); sb.append(companyId); sb.append(", rendererKey="); sb.append(rendererKey); sb.append("}"); throw new NoSuchEntryLinkException(sb.toString()); } /** * Returns the last fragment entry link in the ordered set where companyId = ? and rendererKey = ?. * * @param companyId the company ID * @param rendererKey the renderer key * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByC_R_Last( long companyId, String rendererKey, OrderByComparator orderByComparator) { int count = countByC_R(companyId, rendererKey); if (count == 0) { return null; } List list = findByC_R( companyId, rendererKey, count - 1, count, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the fragment entry links before and after the current fragment entry link in the ordered set where companyId = ? and rendererKey = ?. * * @param fragmentEntryLinkId the primary key of the current fragment entry link * @param companyId the company ID * @param rendererKey the renderer key * @param orderByComparator the comparator to order the set by (optionally null) * @return the previous, current, and next fragment entry link * @throws NoSuchEntryLinkException if a fragment entry link with the primary key could not be found */ @Override public FragmentEntryLink[] findByC_R_PrevAndNext( long fragmentEntryLinkId, long companyId, String rendererKey, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { rendererKey = Objects.toString(rendererKey, ""); FragmentEntryLink fragmentEntryLink = findByPrimaryKey( fragmentEntryLinkId); Session session = null; try { session = openSession(); FragmentEntryLink[] array = new FragmentEntryLinkImpl[3]; array[0] = getByC_R_PrevAndNext( session, fragmentEntryLink, companyId, rendererKey, orderByComparator, true); array[1] = fragmentEntryLink; array[2] = getByC_R_PrevAndNext( session, fragmentEntryLink, companyId, rendererKey, orderByComparator, false); return array; } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } protected FragmentEntryLink getByC_R_PrevAndNext( Session session, FragmentEntryLink fragmentEntryLink, long companyId, String rendererKey, OrderByComparator orderByComparator, boolean previous) { StringBundler sb = null; if (orderByComparator != null) { sb = new StringBundler( 5 + (orderByComparator.getOrderByConditionFields().length * 3) + (orderByComparator.getOrderByFields().length * 3)); } else { sb = new StringBundler(4); } sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_C_R_COMPANYID_2); boolean bindRendererKey = false; if (rendererKey.isEmpty()) { sb.append(_FINDER_COLUMN_C_R_RENDERERKEY_3); } else { bindRendererKey = true; sb.append(_FINDER_COLUMN_C_R_RENDERERKEY_2); } if (orderByComparator != null) { String[] orderByConditionFields = orderByComparator.getOrderByConditionFields(); if (orderByConditionFields.length > 0) { sb.append(WHERE_AND); } for (int i = 0; i < orderByConditionFields.length; i++) { sb.append(_ORDER_BY_ENTITY_ALIAS); sb.append(orderByConditionFields[i]); if ((i + 1) < orderByConditionFields.length) { if (orderByComparator.isAscending() ^ previous) { sb.append(WHERE_GREATER_THAN_HAS_NEXT); } else { sb.append(WHERE_LESSER_THAN_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { sb.append(WHERE_GREATER_THAN); } else { sb.append(WHERE_LESSER_THAN); } } } sb.append(ORDER_BY_CLAUSE); String[] orderByFields = orderByComparator.getOrderByFields(); for (int i = 0; i < orderByFields.length; i++) { sb.append(_ORDER_BY_ENTITY_ALIAS); sb.append(orderByFields[i]); if ((i + 1) < orderByFields.length) { if (orderByComparator.isAscending() ^ previous) { sb.append(ORDER_BY_ASC_HAS_NEXT); } else { sb.append(ORDER_BY_DESC_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { sb.append(ORDER_BY_ASC); } else { sb.append(ORDER_BY_DESC); } } } } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Query query = session.createQuery(sql); query.setFirstResult(0); query.setMaxResults(2); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(companyId); if (bindRendererKey) { queryPos.add(rendererKey); } if (orderByComparator != null) { for (Object orderByConditionValue : orderByComparator.getOrderByConditionValues( fragmentEntryLink)) { queryPos.add(orderByConditionValue); } } List list = query.list(); if (list.size() == 2) { return list.get(1); } else { return null; } } /** * Returns all the fragment entry links where companyId = ? and rendererKey = any ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param companyId the company ID * @param rendererKeys the renderer keys * @return the matching fragment entry links */ @Override public List findByC_R( long companyId, String[] rendererKeys) { return findByC_R( companyId, rendererKeys, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null); } /** * Returns a range of all the fragment entry links where companyId = ? and rendererKey = any ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param companyId the company ID * @param rendererKeys the renderer keys * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @return the range of matching fragment entry links */ @Override public List findByC_R( long companyId, String[] rendererKeys, int start, int end) { return findByC_R(companyId, rendererKeys, start, end, null); } /** * Returns an ordered range of all the fragment entry links where companyId = ? and rendererKey = any ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param companyId the company ID * @param rendererKeys the renderer keys * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @return the ordered range of matching fragment entry links */ @Override public List findByC_R( long companyId, String[] rendererKeys, int start, int end, OrderByComparator orderByComparator) { return findByC_R( companyId, rendererKeys, start, end, orderByComparator, true); } /** * Returns an ordered range of all the fragment entry links where companyId = ? and rendererKey = ?, optionally using the finder cache. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param companyId the company ID * @param rendererKeys the renderer keys * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @param useFinderCache whether to use the finder cache * @return the ordered range of matching fragment entry links */ @Override public List findByC_R( long companyId, String[] rendererKeys, int start, int end, OrderByComparator orderByComparator, boolean useFinderCache) { if (rendererKeys == null) { rendererKeys = new String[0]; } else if (rendererKeys.length > 1) { for (int i = 0; i < rendererKeys.length; i++) { rendererKeys[i] = Objects.toString(rendererKeys[i], ""); } rendererKeys = ArrayUtil.sortedUnique(rendererKeys); } if (rendererKeys.length == 1) { return findByC_R( companyId, rendererKeys[0], start, end, orderByComparator); } try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { Object[] finderArgs = null; if ((start == QueryUtil.ALL_POS) && (end == QueryUtil.ALL_POS) && (orderByComparator == null)) { if (useFinderCache) { finderArgs = new Object[] { companyId, StringUtil.merge(rendererKeys) }; } } else if (useFinderCache) { finderArgs = new Object[] { companyId, StringUtil.merge(rendererKeys), start, end, orderByComparator }; } List list = null; if (useFinderCache) { list = (List)finderCache.getResult( _finderPathWithPaginationFindByC_R, finderArgs, this); if ((list != null) && !list.isEmpty()) { for (FragmentEntryLink fragmentEntryLink : list) { if ((companyId != fragmentEntryLink.getCompanyId()) || !ArrayUtil.contains( rendererKeys, fragmentEntryLink.getRendererKey())) { list = null; break; } } } } if (list == null) { StringBundler sb = new StringBundler(); sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_C_R_COMPANYID_2); if (rendererKeys.length > 0) { sb.append("("); for (int i = 0; i < rendererKeys.length; i++) { String rendererKey = rendererKeys[i]; if (rendererKey.isEmpty()) { sb.append(_FINDER_COLUMN_C_R_RENDERERKEY_3); } else { sb.append(_FINDER_COLUMN_C_R_RENDERERKEY_2); } if ((i + 1) < rendererKeys.length) { sb.append(WHERE_OR); } } sb.append(")"); } sb.setStringAt( removeConjunction(sb.stringAt(sb.index() - 1)), sb.index() - 1); if (orderByComparator != null) { appendOrderByComparator( sb, _ORDER_BY_ENTITY_ALIAS, orderByComparator); } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(companyId); for (String rendererKey : rendererKeys) { if ((rendererKey != null) && !rendererKey.isEmpty()) { queryPos.add(rendererKey); } } list = (List)QueryUtil.list( query, getDialect(), start, end); cacheResult(list); if (useFinderCache) { finderCache.putResult( _finderPathWithPaginationFindByC_R, finderArgs, list); } } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return list; } } /** * Removes all the fragment entry links where companyId = ? and rendererKey = ? from the database. * * @param companyId the company ID * @param rendererKey the renderer key */ @Override public void removeByC_R(long companyId, String rendererKey) { for (FragmentEntryLink fragmentEntryLink : findByC_R( companyId, rendererKey, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null)) { remove(fragmentEntryLink); } } /** * Returns the number of fragment entry links where companyId = ? and rendererKey = ?. * * @param companyId the company ID * @param rendererKey the renderer key * @return the number of matching fragment entry links */ @Override public int countByC_R(long companyId, String rendererKey) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { rendererKey = Objects.toString(rendererKey, ""); FinderPath finderPath = _finderPathCountByC_R; Object[] finderArgs = new Object[] {companyId, rendererKey}; Long count = (Long)finderCache.getResult( finderPath, finderArgs, this); if (count == null) { StringBundler sb = new StringBundler(3); sb.append(_SQL_COUNT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_C_R_COMPANYID_2); boolean bindRendererKey = false; if (rendererKey.isEmpty()) { sb.append(_FINDER_COLUMN_C_R_RENDERERKEY_3); } else { bindRendererKey = true; sb.append(_FINDER_COLUMN_C_R_RENDERERKEY_2); } String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(companyId); if (bindRendererKey) { queryPos.add(rendererKey); } count = (Long)query.uniqueResult(); finderCache.putResult(finderPath, finderArgs, count); } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return count.intValue(); } } /** * Returns the number of fragment entry links where companyId = ? and rendererKey = any ?. * * @param companyId the company ID * @param rendererKeys the renderer keys * @return the number of matching fragment entry links */ @Override public int countByC_R(long companyId, String[] rendererKeys) { if (rendererKeys == null) { rendererKeys = new String[0]; } else if (rendererKeys.length > 1) { for (int i = 0; i < rendererKeys.length; i++) { rendererKeys[i] = Objects.toString(rendererKeys[i], ""); } rendererKeys = ArrayUtil.sortedUnique(rendererKeys); } try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { Object[] finderArgs = new Object[] { companyId, StringUtil.merge(rendererKeys) }; Long count = (Long)finderCache.getResult( _finderPathWithPaginationCountByC_R, finderArgs, this); if (count == null) { StringBundler sb = new StringBundler(); sb.append(_SQL_COUNT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_C_R_COMPANYID_2); if (rendererKeys.length > 0) { sb.append("("); for (int i = 0; i < rendererKeys.length; i++) { String rendererKey = rendererKeys[i]; if (rendererKey.isEmpty()) { sb.append(_FINDER_COLUMN_C_R_RENDERERKEY_3); } else { sb.append(_FINDER_COLUMN_C_R_RENDERERKEY_2); } if ((i + 1) < rendererKeys.length) { sb.append(WHERE_OR); } } sb.append(")"); } sb.setStringAt( removeConjunction(sb.stringAt(sb.index() - 1)), sb.index() - 1); String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(companyId); for (String rendererKey : rendererKeys) { if ((rendererKey != null) && !rendererKey.isEmpty()) { queryPos.add(rendererKey); } } count = (Long)query.uniqueResult(); finderCache.putResult( _finderPathWithPaginationCountByC_R, finderArgs, count); } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return count.intValue(); } } private static final String _FINDER_COLUMN_C_R_COMPANYID_2 = "fragmentEntryLink.companyId = ? AND "; private static final String _FINDER_COLUMN_C_R_RENDERERKEY_2 = "fragmentEntryLink.rendererKey = ?"; private static final String _FINDER_COLUMN_C_R_RENDERERKEY_3 = "(fragmentEntryLink.rendererKey IS NULL OR fragmentEntryLink.rendererKey = '')"; private FinderPath _finderPathWithPaginationFindByF_D; private FinderPath _finderPathWithoutPaginationFindByF_D; private FinderPath _finderPathCountByF_D; private FinderPath _finderPathWithPaginationCountByF_D; /** * Returns all the fragment entry links where fragmentEntryId = ? and deleted = ?. * * @param fragmentEntryId the fragment entry ID * @param deleted the deleted * @return the matching fragment entry links */ @Override public List findByF_D( long fragmentEntryId, boolean deleted) { return findByF_D( fragmentEntryId, deleted, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null); } /** * Returns a range of all the fragment entry links where fragmentEntryId = ? and deleted = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param fragmentEntryId the fragment entry ID * @param deleted the deleted * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @return the range of matching fragment entry links */ @Override public List findByF_D( long fragmentEntryId, boolean deleted, int start, int end) { return findByF_D(fragmentEntryId, deleted, start, end, null); } /** * Returns an ordered range of all the fragment entry links where fragmentEntryId = ? and deleted = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param fragmentEntryId the fragment entry ID * @param deleted the deleted * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @return the ordered range of matching fragment entry links */ @Override public List findByF_D( long fragmentEntryId, boolean deleted, int start, int end, OrderByComparator orderByComparator) { return findByF_D( fragmentEntryId, deleted, start, end, orderByComparator, true); } /** * Returns an ordered range of all the fragment entry links where fragmentEntryId = ? and deleted = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param fragmentEntryId the fragment entry ID * @param deleted the deleted * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @param useFinderCache whether to use the finder cache * @return the ordered range of matching fragment entry links */ @Override public List findByF_D( long fragmentEntryId, boolean deleted, int start, int end, OrderByComparator orderByComparator, boolean useFinderCache) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { FinderPath finderPath = null; Object[] finderArgs = null; if ((start == QueryUtil.ALL_POS) && (end == QueryUtil.ALL_POS) && (orderByComparator == null)) { if (useFinderCache) { finderPath = _finderPathWithoutPaginationFindByF_D; finderArgs = new Object[] {fragmentEntryId, deleted}; } } else if (useFinderCache) { finderPath = _finderPathWithPaginationFindByF_D; finderArgs = new Object[] { fragmentEntryId, deleted, start, end, orderByComparator }; } List list = null; if (useFinderCache) { list = (List)finderCache.getResult( finderPath, finderArgs, this); if ((list != null) && !list.isEmpty()) { for (FragmentEntryLink fragmentEntryLink : list) { if ((fragmentEntryId != fragmentEntryLink.getFragmentEntryId()) || (deleted != fragmentEntryLink.isDeleted())) { list = null; break; } } } } if (list == null) { StringBundler sb = null; if (orderByComparator != null) { sb = new StringBundler( 4 + (orderByComparator.getOrderByFields().length * 2)); } else { sb = new StringBundler(4); } sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_F_D_FRAGMENTENTRYID_2); sb.append(_FINDER_COLUMN_F_D_DELETED_2); if (orderByComparator != null) { appendOrderByComparator( sb, _ORDER_BY_ENTITY_ALIAS, orderByComparator); } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(fragmentEntryId); queryPos.add(deleted); list = (List)QueryUtil.list( query, getDialect(), start, end); cacheResult(list); if (useFinderCache) { finderCache.putResult(finderPath, finderArgs, list); } } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return list; } } /** * Returns the first fragment entry link in the ordered set where fragmentEntryId = ? and deleted = ?. * * @param fragmentEntryId the fragment entry ID * @param deleted the deleted * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByF_D_First( long fragmentEntryId, boolean deleted, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByF_D_First( fragmentEntryId, deleted, orderByComparator); if (fragmentEntryLink != null) { return fragmentEntryLink; } StringBundler sb = new StringBundler(6); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("fragmentEntryId="); sb.append(fragmentEntryId); sb.append(", deleted="); sb.append(deleted); sb.append("}"); throw new NoSuchEntryLinkException(sb.toString()); } /** * Returns the first fragment entry link in the ordered set where fragmentEntryId = ? and deleted = ?. * * @param fragmentEntryId the fragment entry ID * @param deleted the deleted * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByF_D_First( long fragmentEntryId, boolean deleted, OrderByComparator orderByComparator) { List list = findByF_D( fragmentEntryId, deleted, 0, 1, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the last fragment entry link in the ordered set where fragmentEntryId = ? and deleted = ?. * * @param fragmentEntryId the fragment entry ID * @param deleted the deleted * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByF_D_Last( long fragmentEntryId, boolean deleted, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByF_D_Last( fragmentEntryId, deleted, orderByComparator); if (fragmentEntryLink != null) { return fragmentEntryLink; } StringBundler sb = new StringBundler(6); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("fragmentEntryId="); sb.append(fragmentEntryId); sb.append(", deleted="); sb.append(deleted); sb.append("}"); throw new NoSuchEntryLinkException(sb.toString()); } /** * Returns the last fragment entry link in the ordered set where fragmentEntryId = ? and deleted = ?. * * @param fragmentEntryId the fragment entry ID * @param deleted the deleted * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByF_D_Last( long fragmentEntryId, boolean deleted, OrderByComparator orderByComparator) { int count = countByF_D(fragmentEntryId, deleted); if (count == 0) { return null; } List list = findByF_D( fragmentEntryId, deleted, count - 1, count, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the fragment entry links before and after the current fragment entry link in the ordered set where fragmentEntryId = ? and deleted = ?. * * @param fragmentEntryLinkId the primary key of the current fragment entry link * @param fragmentEntryId the fragment entry ID * @param deleted the deleted * @param orderByComparator the comparator to order the set by (optionally null) * @return the previous, current, and next fragment entry link * @throws NoSuchEntryLinkException if a fragment entry link with the primary key could not be found */ @Override public FragmentEntryLink[] findByF_D_PrevAndNext( long fragmentEntryLinkId, long fragmentEntryId, boolean deleted, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = findByPrimaryKey( fragmentEntryLinkId); Session session = null; try { session = openSession(); FragmentEntryLink[] array = new FragmentEntryLinkImpl[3]; array[0] = getByF_D_PrevAndNext( session, fragmentEntryLink, fragmentEntryId, deleted, orderByComparator, true); array[1] = fragmentEntryLink; array[2] = getByF_D_PrevAndNext( session, fragmentEntryLink, fragmentEntryId, deleted, orderByComparator, false); return array; } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } protected FragmentEntryLink getByF_D_PrevAndNext( Session session, FragmentEntryLink fragmentEntryLink, long fragmentEntryId, boolean deleted, OrderByComparator orderByComparator, boolean previous) { StringBundler sb = null; if (orderByComparator != null) { sb = new StringBundler( 5 + (orderByComparator.getOrderByConditionFields().length * 3) + (orderByComparator.getOrderByFields().length * 3)); } else { sb = new StringBundler(4); } sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_F_D_FRAGMENTENTRYID_2); sb.append(_FINDER_COLUMN_F_D_DELETED_2); if (orderByComparator != null) { String[] orderByConditionFields = orderByComparator.getOrderByConditionFields(); if (orderByConditionFields.length > 0) { sb.append(WHERE_AND); } for (int i = 0; i < orderByConditionFields.length; i++) { sb.append(_ORDER_BY_ENTITY_ALIAS); sb.append(orderByConditionFields[i]); if ((i + 1) < orderByConditionFields.length) { if (orderByComparator.isAscending() ^ previous) { sb.append(WHERE_GREATER_THAN_HAS_NEXT); } else { sb.append(WHERE_LESSER_THAN_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { sb.append(WHERE_GREATER_THAN); } else { sb.append(WHERE_LESSER_THAN); } } } sb.append(ORDER_BY_CLAUSE); String[] orderByFields = orderByComparator.getOrderByFields(); for (int i = 0; i < orderByFields.length; i++) { sb.append(_ORDER_BY_ENTITY_ALIAS); sb.append(orderByFields[i]); if ((i + 1) < orderByFields.length) { if (orderByComparator.isAscending() ^ previous) { sb.append(ORDER_BY_ASC_HAS_NEXT); } else { sb.append(ORDER_BY_DESC_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { sb.append(ORDER_BY_ASC); } else { sb.append(ORDER_BY_DESC); } } } } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Query query = session.createQuery(sql); query.setFirstResult(0); query.setMaxResults(2); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(fragmentEntryId); queryPos.add(deleted); if (orderByComparator != null) { for (Object orderByConditionValue : orderByComparator.getOrderByConditionValues( fragmentEntryLink)) { queryPos.add(orderByConditionValue); } } List list = query.list(); if (list.size() == 2) { return list.get(1); } else { return null; } } /** * Returns all the fragment entry links where fragmentEntryId = any ? and deleted = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param fragmentEntryIds the fragment entry IDs * @param deleted the deleted * @return the matching fragment entry links */ @Override public List findByF_D( long[] fragmentEntryIds, boolean deleted) { return findByF_D( fragmentEntryIds, deleted, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null); } /** * Returns a range of all the fragment entry links where fragmentEntryId = any ? and deleted = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param fragmentEntryIds the fragment entry IDs * @param deleted the deleted * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @return the range of matching fragment entry links */ @Override public List findByF_D( long[] fragmentEntryIds, boolean deleted, int start, int end) { return findByF_D(fragmentEntryIds, deleted, start, end, null); } /** * Returns an ordered range of all the fragment entry links where fragmentEntryId = any ? and deleted = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param fragmentEntryIds the fragment entry IDs * @param deleted the deleted * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @return the ordered range of matching fragment entry links */ @Override public List findByF_D( long[] fragmentEntryIds, boolean deleted, int start, int end, OrderByComparator orderByComparator) { return findByF_D( fragmentEntryIds, deleted, start, end, orderByComparator, true); } /** * Returns an ordered range of all the fragment entry links where fragmentEntryId = ? and deleted = ?, optionally using the finder cache. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param fragmentEntryIds the fragment entry IDs * @param deleted the deleted * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @param useFinderCache whether to use the finder cache * @return the ordered range of matching fragment entry links */ @Override public List findByF_D( long[] fragmentEntryIds, boolean deleted, int start, int end, OrderByComparator orderByComparator, boolean useFinderCache) { if (fragmentEntryIds == null) { fragmentEntryIds = new long[0]; } else if (fragmentEntryIds.length > 1) { fragmentEntryIds = ArrayUtil.sortedUnique(fragmentEntryIds); } if (fragmentEntryIds.length == 1) { return findByF_D( fragmentEntryIds[0], deleted, start, end, orderByComparator); } try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { Object[] finderArgs = null; if ((start == QueryUtil.ALL_POS) && (end == QueryUtil.ALL_POS) && (orderByComparator == null)) { if (useFinderCache) { finderArgs = new Object[] { StringUtil.merge(fragmentEntryIds), deleted }; } } else if (useFinderCache) { finderArgs = new Object[] { StringUtil.merge(fragmentEntryIds), deleted, start, end, orderByComparator }; } List list = null; if (useFinderCache) { list = (List)finderCache.getResult( _finderPathWithPaginationFindByF_D, finderArgs, this); if ((list != null) && !list.isEmpty()) { for (FragmentEntryLink fragmentEntryLink : list) { if (!ArrayUtil.contains( fragmentEntryIds, fragmentEntryLink.getFragmentEntryId()) || (deleted != fragmentEntryLink.isDeleted())) { list = null; break; } } } } if (list == null) { StringBundler sb = new StringBundler(); sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); if (fragmentEntryIds.length > 0) { sb.append("("); sb.append(_FINDER_COLUMN_F_D_FRAGMENTENTRYID_7); sb.append(StringUtil.merge(fragmentEntryIds)); sb.append(")"); sb.append(")"); sb.append(WHERE_AND); } sb.append(_FINDER_COLUMN_F_D_DELETED_2); sb.setStringAt( removeConjunction(sb.stringAt(sb.index() - 1)), sb.index() - 1); if (orderByComparator != null) { appendOrderByComparator( sb, _ORDER_BY_ENTITY_ALIAS, orderByComparator); } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(deleted); list = (List)QueryUtil.list( query, getDialect(), start, end); cacheResult(list); if (useFinderCache) { finderCache.putResult( _finderPathWithPaginationFindByF_D, finderArgs, list); } } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return list; } } /** * Removes all the fragment entry links where fragmentEntryId = ? and deleted = ? from the database. * * @param fragmentEntryId the fragment entry ID * @param deleted the deleted */ @Override public void removeByF_D(long fragmentEntryId, boolean deleted) { for (FragmentEntryLink fragmentEntryLink : findByF_D( fragmentEntryId, deleted, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null)) { remove(fragmentEntryLink); } } /** * Returns the number of fragment entry links where fragmentEntryId = ? and deleted = ?. * * @param fragmentEntryId the fragment entry ID * @param deleted the deleted * @return the number of matching fragment entry links */ @Override public int countByF_D(long fragmentEntryId, boolean deleted) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { FinderPath finderPath = _finderPathCountByF_D; Object[] finderArgs = new Object[] {fragmentEntryId, deleted}; Long count = (Long)finderCache.getResult( finderPath, finderArgs, this); if (count == null) { StringBundler sb = new StringBundler(3); sb.append(_SQL_COUNT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_F_D_FRAGMENTENTRYID_2); sb.append(_FINDER_COLUMN_F_D_DELETED_2); String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(fragmentEntryId); queryPos.add(deleted); count = (Long)query.uniqueResult(); finderCache.putResult(finderPath, finderArgs, count); } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return count.intValue(); } } /** * Returns the number of fragment entry links where fragmentEntryId = any ? and deleted = ?. * * @param fragmentEntryIds the fragment entry IDs * @param deleted the deleted * @return the number of matching fragment entry links */ @Override public int countByF_D(long[] fragmentEntryIds, boolean deleted) { if (fragmentEntryIds == null) { fragmentEntryIds = new long[0]; } else if (fragmentEntryIds.length > 1) { fragmentEntryIds = ArrayUtil.sortedUnique(fragmentEntryIds); } try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { Object[] finderArgs = new Object[] { StringUtil.merge(fragmentEntryIds), deleted }; Long count = (Long)finderCache.getResult( _finderPathWithPaginationCountByF_D, finderArgs, this); if (count == null) { StringBundler sb = new StringBundler(); sb.append(_SQL_COUNT_FRAGMENTENTRYLINK_WHERE); if (fragmentEntryIds.length > 0) { sb.append("("); sb.append(_FINDER_COLUMN_F_D_FRAGMENTENTRYID_7); sb.append(StringUtil.merge(fragmentEntryIds)); sb.append(")"); sb.append(")"); sb.append(WHERE_AND); } sb.append(_FINDER_COLUMN_F_D_DELETED_2); sb.setStringAt( removeConjunction(sb.stringAt(sb.index() - 1)), sb.index() - 1); String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(deleted); count = (Long)query.uniqueResult(); finderCache.putResult( _finderPathWithPaginationCountByF_D, finderArgs, count); } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return count.intValue(); } } private static final String _FINDER_COLUMN_F_D_FRAGMENTENTRYID_2 = "fragmentEntryLink.fragmentEntryId = ? AND "; private static final String _FINDER_COLUMN_F_D_FRAGMENTENTRYID_7 = "fragmentEntryLink.fragmentEntryId IN ("; private static final String _FINDER_COLUMN_F_D_DELETED_2 = "fragmentEntryLink.deleted = ?"; private FinderPath _finderPathWithPaginationFindByG_OFELI_P; private FinderPath _finderPathWithoutPaginationFindByG_OFELI_P; private FinderPath _finderPathCountByG_OFELI_P; /** * Returns all the fragment entry links where groupId = ? and originalFragmentEntryLinkId = ? and plid = ?. * * @param groupId the group ID * @param originalFragmentEntryLinkId the original fragment entry link ID * @param plid the plid * @return the matching fragment entry links */ @Override public List findByG_OFELI_P( long groupId, long originalFragmentEntryLinkId, long plid) { return findByG_OFELI_P( groupId, originalFragmentEntryLinkId, plid, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null); } /** * Returns a range of all the fragment entry links where groupId = ? and originalFragmentEntryLinkId = ? and plid = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param originalFragmentEntryLinkId the original fragment entry link ID * @param plid the plid * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @return the range of matching fragment entry links */ @Override public List findByG_OFELI_P( long groupId, long originalFragmentEntryLinkId, long plid, int start, int end) { return findByG_OFELI_P( groupId, originalFragmentEntryLinkId, plid, start, end, null); } /** * Returns an ordered range of all the fragment entry links where groupId = ? and originalFragmentEntryLinkId = ? and plid = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param originalFragmentEntryLinkId the original fragment entry link ID * @param plid the plid * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @return the ordered range of matching fragment entry links */ @Override public List findByG_OFELI_P( long groupId, long originalFragmentEntryLinkId, long plid, int start, int end, OrderByComparator orderByComparator) { return findByG_OFELI_P( groupId, originalFragmentEntryLinkId, plid, start, end, orderByComparator, true); } /** * Returns an ordered range of all the fragment entry links where groupId = ? and originalFragmentEntryLinkId = ? and plid = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param originalFragmentEntryLinkId the original fragment entry link ID * @param plid the plid * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @param useFinderCache whether to use the finder cache * @return the ordered range of matching fragment entry links */ @Override public List findByG_OFELI_P( long groupId, long originalFragmentEntryLinkId, long plid, int start, int end, OrderByComparator orderByComparator, boolean useFinderCache) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { FinderPath finderPath = null; Object[] finderArgs = null; if ((start == QueryUtil.ALL_POS) && (end == QueryUtil.ALL_POS) && (orderByComparator == null)) { if (useFinderCache) { finderPath = _finderPathWithoutPaginationFindByG_OFELI_P; finderArgs = new Object[] { groupId, originalFragmentEntryLinkId, plid }; } } else if (useFinderCache) { finderPath = _finderPathWithPaginationFindByG_OFELI_P; finderArgs = new Object[] { groupId, originalFragmentEntryLinkId, plid, start, end, orderByComparator }; } List list = null; if (useFinderCache) { list = (List)finderCache.getResult( finderPath, finderArgs, this); if ((list != null) && !list.isEmpty()) { for (FragmentEntryLink fragmentEntryLink : list) { if ((groupId != fragmentEntryLink.getGroupId()) || (originalFragmentEntryLinkId != fragmentEntryLink. getOriginalFragmentEntryLinkId()) || (plid != fragmentEntryLink.getPlid())) { list = null; break; } } } } if (list == null) { StringBundler sb = null; if (orderByComparator != null) { sb = new StringBundler( 5 + (orderByComparator.getOrderByFields().length * 2)); } else { sb = new StringBundler(5); } sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_OFELI_P_GROUPID_2); sb.append( _FINDER_COLUMN_G_OFELI_P_ORIGINALFRAGMENTENTRYLINKID_2); sb.append(_FINDER_COLUMN_G_OFELI_P_PLID_2); if (orderByComparator != null) { appendOrderByComparator( sb, _ORDER_BY_ENTITY_ALIAS, orderByComparator); } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(originalFragmentEntryLinkId); queryPos.add(plid); list = (List)QueryUtil.list( query, getDialect(), start, end); cacheResult(list); if (useFinderCache) { finderCache.putResult(finderPath, finderArgs, list); } } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return list; } } /** * Returns the first fragment entry link in the ordered set where groupId = ? and originalFragmentEntryLinkId = ? and plid = ?. * * @param groupId the group ID * @param originalFragmentEntryLinkId the original fragment entry link ID * @param plid the plid * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByG_OFELI_P_First( long groupId, long originalFragmentEntryLinkId, long plid, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByG_OFELI_P_First( groupId, originalFragmentEntryLinkId, plid, orderByComparator); if (fragmentEntryLink != null) { return fragmentEntryLink; } StringBundler sb = new StringBundler(8); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("groupId="); sb.append(groupId); sb.append(", originalFragmentEntryLinkId="); sb.append(originalFragmentEntryLinkId); sb.append(", plid="); sb.append(plid); sb.append("}"); throw new NoSuchEntryLinkException(sb.toString()); } /** * Returns the first fragment entry link in the ordered set where groupId = ? and originalFragmentEntryLinkId = ? and plid = ?. * * @param groupId the group ID * @param originalFragmentEntryLinkId the original fragment entry link ID * @param plid the plid * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByG_OFELI_P_First( long groupId, long originalFragmentEntryLinkId, long plid, OrderByComparator orderByComparator) { List list = findByG_OFELI_P( groupId, originalFragmentEntryLinkId, plid, 0, 1, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the last fragment entry link in the ordered set where groupId = ? and originalFragmentEntryLinkId = ? and plid = ?. * * @param groupId the group ID * @param originalFragmentEntryLinkId the original fragment entry link ID * @param plid the plid * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByG_OFELI_P_Last( long groupId, long originalFragmentEntryLinkId, long plid, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByG_OFELI_P_Last( groupId, originalFragmentEntryLinkId, plid, orderByComparator); if (fragmentEntryLink != null) { return fragmentEntryLink; } StringBundler sb = new StringBundler(8); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("groupId="); sb.append(groupId); sb.append(", originalFragmentEntryLinkId="); sb.append(originalFragmentEntryLinkId); sb.append(", plid="); sb.append(plid); sb.append("}"); throw new NoSuchEntryLinkException(sb.toString()); } /** * Returns the last fragment entry link in the ordered set where groupId = ? and originalFragmentEntryLinkId = ? and plid = ?. * * @param groupId the group ID * @param originalFragmentEntryLinkId the original fragment entry link ID * @param plid the plid * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByG_OFELI_P_Last( long groupId, long originalFragmentEntryLinkId, long plid, OrderByComparator orderByComparator) { int count = countByG_OFELI_P( groupId, originalFragmentEntryLinkId, plid); if (count == 0) { return null; } List list = findByG_OFELI_P( groupId, originalFragmentEntryLinkId, plid, count - 1, count, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the fragment entry links before and after the current fragment entry link in the ordered set where groupId = ? and originalFragmentEntryLinkId = ? and plid = ?. * * @param fragmentEntryLinkId the primary key of the current fragment entry link * @param groupId the group ID * @param originalFragmentEntryLinkId the original fragment entry link ID * @param plid the plid * @param orderByComparator the comparator to order the set by (optionally null) * @return the previous, current, and next fragment entry link * @throws NoSuchEntryLinkException if a fragment entry link with the primary key could not be found */ @Override public FragmentEntryLink[] findByG_OFELI_P_PrevAndNext( long fragmentEntryLinkId, long groupId, long originalFragmentEntryLinkId, long plid, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = findByPrimaryKey( fragmentEntryLinkId); Session session = null; try { session = openSession(); FragmentEntryLink[] array = new FragmentEntryLinkImpl[3]; array[0] = getByG_OFELI_P_PrevAndNext( session, fragmentEntryLink, groupId, originalFragmentEntryLinkId, plid, orderByComparator, true); array[1] = fragmentEntryLink; array[2] = getByG_OFELI_P_PrevAndNext( session, fragmentEntryLink, groupId, originalFragmentEntryLinkId, plid, orderByComparator, false); return array; } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } protected FragmentEntryLink getByG_OFELI_P_PrevAndNext( Session session, FragmentEntryLink fragmentEntryLink, long groupId, long originalFragmentEntryLinkId, long plid, OrderByComparator orderByComparator, boolean previous) { StringBundler sb = null; if (orderByComparator != null) { sb = new StringBundler( 6 + (orderByComparator.getOrderByConditionFields().length * 3) + (orderByComparator.getOrderByFields().length * 3)); } else { sb = new StringBundler(5); } sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_OFELI_P_GROUPID_2); sb.append(_FINDER_COLUMN_G_OFELI_P_ORIGINALFRAGMENTENTRYLINKID_2); sb.append(_FINDER_COLUMN_G_OFELI_P_PLID_2); if (orderByComparator != null) { String[] orderByConditionFields = orderByComparator.getOrderByConditionFields(); if (orderByConditionFields.length > 0) { sb.append(WHERE_AND); } for (int i = 0; i < orderByConditionFields.length; i++) { sb.append(_ORDER_BY_ENTITY_ALIAS); sb.append(orderByConditionFields[i]); if ((i + 1) < orderByConditionFields.length) { if (orderByComparator.isAscending() ^ previous) { sb.append(WHERE_GREATER_THAN_HAS_NEXT); } else { sb.append(WHERE_LESSER_THAN_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { sb.append(WHERE_GREATER_THAN); } else { sb.append(WHERE_LESSER_THAN); } } } sb.append(ORDER_BY_CLAUSE); String[] orderByFields = orderByComparator.getOrderByFields(); for (int i = 0; i < orderByFields.length; i++) { sb.append(_ORDER_BY_ENTITY_ALIAS); sb.append(orderByFields[i]); if ((i + 1) < orderByFields.length) { if (orderByComparator.isAscending() ^ previous) { sb.append(ORDER_BY_ASC_HAS_NEXT); } else { sb.append(ORDER_BY_DESC_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { sb.append(ORDER_BY_ASC); } else { sb.append(ORDER_BY_DESC); } } } } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Query query = session.createQuery(sql); query.setFirstResult(0); query.setMaxResults(2); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(originalFragmentEntryLinkId); queryPos.add(plid); if (orderByComparator != null) { for (Object orderByConditionValue : orderByComparator.getOrderByConditionValues( fragmentEntryLink)) { queryPos.add(orderByConditionValue); } } List list = query.list(); if (list.size() == 2) { return list.get(1); } else { return null; } } /** * Removes all the fragment entry links where groupId = ? and originalFragmentEntryLinkId = ? and plid = ? from the database. * * @param groupId the group ID * @param originalFragmentEntryLinkId the original fragment entry link ID * @param plid the plid */ @Override public void removeByG_OFELI_P( long groupId, long originalFragmentEntryLinkId, long plid) { for (FragmentEntryLink fragmentEntryLink : findByG_OFELI_P( groupId, originalFragmentEntryLinkId, plid, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null)) { remove(fragmentEntryLink); } } /** * Returns the number of fragment entry links where groupId = ? and originalFragmentEntryLinkId = ? and plid = ?. * * @param groupId the group ID * @param originalFragmentEntryLinkId the original fragment entry link ID * @param plid the plid * @return the number of matching fragment entry links */ @Override public int countByG_OFELI_P( long groupId, long originalFragmentEntryLinkId, long plid) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { FinderPath finderPath = _finderPathCountByG_OFELI_P; Object[] finderArgs = new Object[] { groupId, originalFragmentEntryLinkId, plid }; Long count = (Long)finderCache.getResult( finderPath, finderArgs, this); if (count == null) { StringBundler sb = new StringBundler(4); sb.append(_SQL_COUNT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_OFELI_P_GROUPID_2); sb.append( _FINDER_COLUMN_G_OFELI_P_ORIGINALFRAGMENTENTRYLINKID_2); sb.append(_FINDER_COLUMN_G_OFELI_P_PLID_2); String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(originalFragmentEntryLinkId); queryPos.add(plid); count = (Long)query.uniqueResult(); finderCache.putResult(finderPath, finderArgs, count); } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return count.intValue(); } } private static final String _FINDER_COLUMN_G_OFELI_P_GROUPID_2 = "fragmentEntryLink.groupId = ? AND "; private static final String _FINDER_COLUMN_G_OFELI_P_ORIGINALFRAGMENTENTRYLINKID_2 = "fragmentEntryLink.originalFragmentEntryLinkId = ? AND "; private static final String _FINDER_COLUMN_G_OFELI_P_PLID_2 = "fragmentEntryLink.plid = ?"; private FinderPath _finderPathWithPaginationFindByG_F_C; private FinderPath _finderPathWithoutPaginationFindByG_F_C; private FinderPath _finderPathCountByG_F_C; /** * Returns all the fragment entry links where groupId = ? and fragmentEntryId = ? and classNameId = ?. * * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param classNameId the class name ID * @return the matching fragment entry links */ @Override public List findByG_F_C( long groupId, long fragmentEntryId, long classNameId) { return findByG_F_C( groupId, fragmentEntryId, classNameId, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null); } /** * Returns a range of all the fragment entry links where groupId = ? and fragmentEntryId = ? and classNameId = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param classNameId the class name ID * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @return the range of matching fragment entry links */ @Override public List findByG_F_C( long groupId, long fragmentEntryId, long classNameId, int start, int end) { return findByG_F_C( groupId, fragmentEntryId, classNameId, start, end, null); } /** * Returns an ordered range of all the fragment entry links where groupId = ? and fragmentEntryId = ? and classNameId = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param classNameId the class name ID * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @return the ordered range of matching fragment entry links */ @Override public List findByG_F_C( long groupId, long fragmentEntryId, long classNameId, int start, int end, OrderByComparator orderByComparator) { return findByG_F_C( groupId, fragmentEntryId, classNameId, start, end, orderByComparator, true); } /** * Returns an ordered range of all the fragment entry links where groupId = ? and fragmentEntryId = ? and classNameId = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param classNameId the class name ID * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @param useFinderCache whether to use the finder cache * @return the ordered range of matching fragment entry links */ @Override public List findByG_F_C( long groupId, long fragmentEntryId, long classNameId, int start, int end, OrderByComparator orderByComparator, boolean useFinderCache) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { FinderPath finderPath = null; Object[] finderArgs = null; if ((start == QueryUtil.ALL_POS) && (end == QueryUtil.ALL_POS) && (orderByComparator == null)) { if (useFinderCache) { finderPath = _finderPathWithoutPaginationFindByG_F_C; finderArgs = new Object[] { groupId, fragmentEntryId, classNameId }; } } else if (useFinderCache) { finderPath = _finderPathWithPaginationFindByG_F_C; finderArgs = new Object[] { groupId, fragmentEntryId, classNameId, start, end, orderByComparator }; } List list = null; if (useFinderCache) { list = (List)finderCache.getResult( finderPath, finderArgs, this); if ((list != null) && !list.isEmpty()) { for (FragmentEntryLink fragmentEntryLink : list) { if ((groupId != fragmentEntryLink.getGroupId()) || (fragmentEntryId != fragmentEntryLink.getFragmentEntryId()) || (classNameId != fragmentEntryLink.getClassNameId())) { list = null; break; } } } } if (list == null) { StringBundler sb = null; if (orderByComparator != null) { sb = new StringBundler( 5 + (orderByComparator.getOrderByFields().length * 2)); } else { sb = new StringBundler(5); } sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_F_C_GROUPID_2); sb.append(_FINDER_COLUMN_G_F_C_FRAGMENTENTRYID_2); sb.append(_FINDER_COLUMN_G_F_C_CLASSNAMEID_2); if (orderByComparator != null) { appendOrderByComparator( sb, _ORDER_BY_ENTITY_ALIAS, orderByComparator); } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(fragmentEntryId); queryPos.add(classNameId); list = (List)QueryUtil.list( query, getDialect(), start, end); cacheResult(list); if (useFinderCache) { finderCache.putResult(finderPath, finderArgs, list); } } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return list; } } /** * Returns the first fragment entry link in the ordered set where groupId = ? and fragmentEntryId = ? and classNameId = ?. * * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param classNameId the class name ID * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByG_F_C_First( long groupId, long fragmentEntryId, long classNameId, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByG_F_C_First( groupId, fragmentEntryId, classNameId, orderByComparator); if (fragmentEntryLink != null) { return fragmentEntryLink; } StringBundler sb = new StringBundler(8); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("groupId="); sb.append(groupId); sb.append(", fragmentEntryId="); sb.append(fragmentEntryId); sb.append(", classNameId="); sb.append(classNameId); sb.append("}"); throw new NoSuchEntryLinkException(sb.toString()); } /** * Returns the first fragment entry link in the ordered set where groupId = ? and fragmentEntryId = ? and classNameId = ?. * * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param classNameId the class name ID * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByG_F_C_First( long groupId, long fragmentEntryId, long classNameId, OrderByComparator orderByComparator) { List list = findByG_F_C( groupId, fragmentEntryId, classNameId, 0, 1, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the last fragment entry link in the ordered set where groupId = ? and fragmentEntryId = ? and classNameId = ?. * * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param classNameId the class name ID * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByG_F_C_Last( long groupId, long fragmentEntryId, long classNameId, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByG_F_C_Last( groupId, fragmentEntryId, classNameId, orderByComparator); if (fragmentEntryLink != null) { return fragmentEntryLink; } StringBundler sb = new StringBundler(8); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("groupId="); sb.append(groupId); sb.append(", fragmentEntryId="); sb.append(fragmentEntryId); sb.append(", classNameId="); sb.append(classNameId); sb.append("}"); throw new NoSuchEntryLinkException(sb.toString()); } /** * Returns the last fragment entry link in the ordered set where groupId = ? and fragmentEntryId = ? and classNameId = ?. * * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param classNameId the class name ID * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByG_F_C_Last( long groupId, long fragmentEntryId, long classNameId, OrderByComparator orderByComparator) { int count = countByG_F_C(groupId, fragmentEntryId, classNameId); if (count == 0) { return null; } List list = findByG_F_C( groupId, fragmentEntryId, classNameId, count - 1, count, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the fragment entry links before and after the current fragment entry link in the ordered set where groupId = ? and fragmentEntryId = ? and classNameId = ?. * * @param fragmentEntryLinkId the primary key of the current fragment entry link * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param classNameId the class name ID * @param orderByComparator the comparator to order the set by (optionally null) * @return the previous, current, and next fragment entry link * @throws NoSuchEntryLinkException if a fragment entry link with the primary key could not be found */ @Override public FragmentEntryLink[] findByG_F_C_PrevAndNext( long fragmentEntryLinkId, long groupId, long fragmentEntryId, long classNameId, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = findByPrimaryKey( fragmentEntryLinkId); Session session = null; try { session = openSession(); FragmentEntryLink[] array = new FragmentEntryLinkImpl[3]; array[0] = getByG_F_C_PrevAndNext( session, fragmentEntryLink, groupId, fragmentEntryId, classNameId, orderByComparator, true); array[1] = fragmentEntryLink; array[2] = getByG_F_C_PrevAndNext( session, fragmentEntryLink, groupId, fragmentEntryId, classNameId, orderByComparator, false); return array; } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } protected FragmentEntryLink getByG_F_C_PrevAndNext( Session session, FragmentEntryLink fragmentEntryLink, long groupId, long fragmentEntryId, long classNameId, OrderByComparator orderByComparator, boolean previous) { StringBundler sb = null; if (orderByComparator != null) { sb = new StringBundler( 6 + (orderByComparator.getOrderByConditionFields().length * 3) + (orderByComparator.getOrderByFields().length * 3)); } else { sb = new StringBundler(5); } sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_F_C_GROUPID_2); sb.append(_FINDER_COLUMN_G_F_C_FRAGMENTENTRYID_2); sb.append(_FINDER_COLUMN_G_F_C_CLASSNAMEID_2); if (orderByComparator != null) { String[] orderByConditionFields = orderByComparator.getOrderByConditionFields(); if (orderByConditionFields.length > 0) { sb.append(WHERE_AND); } for (int i = 0; i < orderByConditionFields.length; i++) { sb.append(_ORDER_BY_ENTITY_ALIAS); sb.append(orderByConditionFields[i]); if ((i + 1) < orderByConditionFields.length) { if (orderByComparator.isAscending() ^ previous) { sb.append(WHERE_GREATER_THAN_HAS_NEXT); } else { sb.append(WHERE_LESSER_THAN_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { sb.append(WHERE_GREATER_THAN); } else { sb.append(WHERE_LESSER_THAN); } } } sb.append(ORDER_BY_CLAUSE); String[] orderByFields = orderByComparator.getOrderByFields(); for (int i = 0; i < orderByFields.length; i++) { sb.append(_ORDER_BY_ENTITY_ALIAS); sb.append(orderByFields[i]); if ((i + 1) < orderByFields.length) { if (orderByComparator.isAscending() ^ previous) { sb.append(ORDER_BY_ASC_HAS_NEXT); } else { sb.append(ORDER_BY_DESC_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { sb.append(ORDER_BY_ASC); } else { sb.append(ORDER_BY_DESC); } } } } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Query query = session.createQuery(sql); query.setFirstResult(0); query.setMaxResults(2); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(fragmentEntryId); queryPos.add(classNameId); if (orderByComparator != null) { for (Object orderByConditionValue : orderByComparator.getOrderByConditionValues( fragmentEntryLink)) { queryPos.add(orderByConditionValue); } } List list = query.list(); if (list.size() == 2) { return list.get(1); } else { return null; } } /** * Removes all the fragment entry links where groupId = ? and fragmentEntryId = ? and classNameId = ? from the database. * * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param classNameId the class name ID */ @Override public void removeByG_F_C( long groupId, long fragmentEntryId, long classNameId) { for (FragmentEntryLink fragmentEntryLink : findByG_F_C( groupId, fragmentEntryId, classNameId, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null)) { remove(fragmentEntryLink); } } /** * Returns the number of fragment entry links where groupId = ? and fragmentEntryId = ? and classNameId = ?. * * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param classNameId the class name ID * @return the number of matching fragment entry links */ @Override public int countByG_F_C( long groupId, long fragmentEntryId, long classNameId) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { FinderPath finderPath = _finderPathCountByG_F_C; Object[] finderArgs = new Object[] { groupId, fragmentEntryId, classNameId }; Long count = (Long)finderCache.getResult( finderPath, finderArgs, this); if (count == null) { StringBundler sb = new StringBundler(4); sb.append(_SQL_COUNT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_F_C_GROUPID_2); sb.append(_FINDER_COLUMN_G_F_C_FRAGMENTENTRYID_2); sb.append(_FINDER_COLUMN_G_F_C_CLASSNAMEID_2); String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(fragmentEntryId); queryPos.add(classNameId); count = (Long)query.uniqueResult(); finderCache.putResult(finderPath, finderArgs, count); } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return count.intValue(); } } private static final String _FINDER_COLUMN_G_F_C_GROUPID_2 = "fragmentEntryLink.groupId = ? AND "; private static final String _FINDER_COLUMN_G_F_C_FRAGMENTENTRYID_2 = "fragmentEntryLink.fragmentEntryId = ? AND "; private static final String _FINDER_COLUMN_G_F_C_CLASSNAMEID_2 = "fragmentEntryLink.classNameId = ?"; private FinderPath _finderPathWithPaginationFindByG_F_P; private FinderPath _finderPathWithoutPaginationFindByG_F_P; private FinderPath _finderPathCountByG_F_P; /** * Returns all the fragment entry links where groupId = ? and fragmentEntryId = ? and plid = ?. * * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param plid the plid * @return the matching fragment entry links */ @Override public List findByG_F_P( long groupId, long fragmentEntryId, long plid) { return findByG_F_P( groupId, fragmentEntryId, plid, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null); } /** * Returns a range of all the fragment entry links where groupId = ? and fragmentEntryId = ? and plid = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param plid the plid * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @return the range of matching fragment entry links */ @Override public List findByG_F_P( long groupId, long fragmentEntryId, long plid, int start, int end) { return findByG_F_P(groupId, fragmentEntryId, plid, start, end, null); } /** * Returns an ordered range of all the fragment entry links where groupId = ? and fragmentEntryId = ? and plid = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param plid the plid * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @return the ordered range of matching fragment entry links */ @Override public List findByG_F_P( long groupId, long fragmentEntryId, long plid, int start, int end, OrderByComparator orderByComparator) { return findByG_F_P( groupId, fragmentEntryId, plid, start, end, orderByComparator, true); } /** * Returns an ordered range of all the fragment entry links where groupId = ? and fragmentEntryId = ? and plid = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param plid the plid * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @param useFinderCache whether to use the finder cache * @return the ordered range of matching fragment entry links */ @Override public List findByG_F_P( long groupId, long fragmentEntryId, long plid, int start, int end, OrderByComparator orderByComparator, boolean useFinderCache) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { FinderPath finderPath = null; Object[] finderArgs = null; if ((start == QueryUtil.ALL_POS) && (end == QueryUtil.ALL_POS) && (orderByComparator == null)) { if (useFinderCache) { finderPath = _finderPathWithoutPaginationFindByG_F_P; finderArgs = new Object[] {groupId, fragmentEntryId, plid}; } } else if (useFinderCache) { finderPath = _finderPathWithPaginationFindByG_F_P; finderArgs = new Object[] { groupId, fragmentEntryId, plid, start, end, orderByComparator }; } List list = null; if (useFinderCache) { list = (List)finderCache.getResult( finderPath, finderArgs, this); if ((list != null) && !list.isEmpty()) { for (FragmentEntryLink fragmentEntryLink : list) { if ((groupId != fragmentEntryLink.getGroupId()) || (fragmentEntryId != fragmentEntryLink.getFragmentEntryId()) || (plid != fragmentEntryLink.getPlid())) { list = null; break; } } } } if (list == null) { StringBundler sb = null; if (orderByComparator != null) { sb = new StringBundler( 5 + (orderByComparator.getOrderByFields().length * 2)); } else { sb = new StringBundler(5); } sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_F_P_GROUPID_2); sb.append(_FINDER_COLUMN_G_F_P_FRAGMENTENTRYID_2); sb.append(_FINDER_COLUMN_G_F_P_PLID_2); if (orderByComparator != null) { appendOrderByComparator( sb, _ORDER_BY_ENTITY_ALIAS, orderByComparator); } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(fragmentEntryId); queryPos.add(plid); list = (List)QueryUtil.list( query, getDialect(), start, end); cacheResult(list); if (useFinderCache) { finderCache.putResult(finderPath, finderArgs, list); } } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return list; } } /** * Returns the first fragment entry link in the ordered set where groupId = ? and fragmentEntryId = ? and plid = ?. * * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param plid the plid * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByG_F_P_First( long groupId, long fragmentEntryId, long plid, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByG_F_P_First( groupId, fragmentEntryId, plid, orderByComparator); if (fragmentEntryLink != null) { return fragmentEntryLink; } StringBundler sb = new StringBundler(8); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("groupId="); sb.append(groupId); sb.append(", fragmentEntryId="); sb.append(fragmentEntryId); sb.append(", plid="); sb.append(plid); sb.append("}"); throw new NoSuchEntryLinkException(sb.toString()); } /** * Returns the first fragment entry link in the ordered set where groupId = ? and fragmentEntryId = ? and plid = ?. * * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param plid the plid * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByG_F_P_First( long groupId, long fragmentEntryId, long plid, OrderByComparator orderByComparator) { List list = findByG_F_P( groupId, fragmentEntryId, plid, 0, 1, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the last fragment entry link in the ordered set where groupId = ? and fragmentEntryId = ? and plid = ?. * * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param plid the plid * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByG_F_P_Last( long groupId, long fragmentEntryId, long plid, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByG_F_P_Last( groupId, fragmentEntryId, plid, orderByComparator); if (fragmentEntryLink != null) { return fragmentEntryLink; } StringBundler sb = new StringBundler(8); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("groupId="); sb.append(groupId); sb.append(", fragmentEntryId="); sb.append(fragmentEntryId); sb.append(", plid="); sb.append(plid); sb.append("}"); throw new NoSuchEntryLinkException(sb.toString()); } /** * Returns the last fragment entry link in the ordered set where groupId = ? and fragmentEntryId = ? and plid = ?. * * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param plid the plid * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByG_F_P_Last( long groupId, long fragmentEntryId, long plid, OrderByComparator orderByComparator) { int count = countByG_F_P(groupId, fragmentEntryId, plid); if (count == 0) { return null; } List list = findByG_F_P( groupId, fragmentEntryId, plid, count - 1, count, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the fragment entry links before and after the current fragment entry link in the ordered set where groupId = ? and fragmentEntryId = ? and plid = ?. * * @param fragmentEntryLinkId the primary key of the current fragment entry link * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param plid the plid * @param orderByComparator the comparator to order the set by (optionally null) * @return the previous, current, and next fragment entry link * @throws NoSuchEntryLinkException if a fragment entry link with the primary key could not be found */ @Override public FragmentEntryLink[] findByG_F_P_PrevAndNext( long fragmentEntryLinkId, long groupId, long fragmentEntryId, long plid, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = findByPrimaryKey( fragmentEntryLinkId); Session session = null; try { session = openSession(); FragmentEntryLink[] array = new FragmentEntryLinkImpl[3]; array[0] = getByG_F_P_PrevAndNext( session, fragmentEntryLink, groupId, fragmentEntryId, plid, orderByComparator, true); array[1] = fragmentEntryLink; array[2] = getByG_F_P_PrevAndNext( session, fragmentEntryLink, groupId, fragmentEntryId, plid, orderByComparator, false); return array; } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } protected FragmentEntryLink getByG_F_P_PrevAndNext( Session session, FragmentEntryLink fragmentEntryLink, long groupId, long fragmentEntryId, long plid, OrderByComparator orderByComparator, boolean previous) { StringBundler sb = null; if (orderByComparator != null) { sb = new StringBundler( 6 + (orderByComparator.getOrderByConditionFields().length * 3) + (orderByComparator.getOrderByFields().length * 3)); } else { sb = new StringBundler(5); } sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_F_P_GROUPID_2); sb.append(_FINDER_COLUMN_G_F_P_FRAGMENTENTRYID_2); sb.append(_FINDER_COLUMN_G_F_P_PLID_2); if (orderByComparator != null) { String[] orderByConditionFields = orderByComparator.getOrderByConditionFields(); if (orderByConditionFields.length > 0) { sb.append(WHERE_AND); } for (int i = 0; i < orderByConditionFields.length; i++) { sb.append(_ORDER_BY_ENTITY_ALIAS); sb.append(orderByConditionFields[i]); if ((i + 1) < orderByConditionFields.length) { if (orderByComparator.isAscending() ^ previous) { sb.append(WHERE_GREATER_THAN_HAS_NEXT); } else { sb.append(WHERE_LESSER_THAN_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { sb.append(WHERE_GREATER_THAN); } else { sb.append(WHERE_LESSER_THAN); } } } sb.append(ORDER_BY_CLAUSE); String[] orderByFields = orderByComparator.getOrderByFields(); for (int i = 0; i < orderByFields.length; i++) { sb.append(_ORDER_BY_ENTITY_ALIAS); sb.append(orderByFields[i]); if ((i + 1) < orderByFields.length) { if (orderByComparator.isAscending() ^ previous) { sb.append(ORDER_BY_ASC_HAS_NEXT); } else { sb.append(ORDER_BY_DESC_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { sb.append(ORDER_BY_ASC); } else { sb.append(ORDER_BY_DESC); } } } } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Query query = session.createQuery(sql); query.setFirstResult(0); query.setMaxResults(2); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(fragmentEntryId); queryPos.add(plid); if (orderByComparator != null) { for (Object orderByConditionValue : orderByComparator.getOrderByConditionValues( fragmentEntryLink)) { queryPos.add(orderByConditionValue); } } List list = query.list(); if (list.size() == 2) { return list.get(1); } else { return null; } } /** * Removes all the fragment entry links where groupId = ? and fragmentEntryId = ? and plid = ? from the database. * * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param plid the plid */ @Override public void removeByG_F_P(long groupId, long fragmentEntryId, long plid) { for (FragmentEntryLink fragmentEntryLink : findByG_F_P( groupId, fragmentEntryId, plid, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null)) { remove(fragmentEntryLink); } } /** * Returns the number of fragment entry links where groupId = ? and fragmentEntryId = ? and plid = ?. * * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param plid the plid * @return the number of matching fragment entry links */ @Override public int countByG_F_P(long groupId, long fragmentEntryId, long plid) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { FinderPath finderPath = _finderPathCountByG_F_P; Object[] finderArgs = new Object[] {groupId, fragmentEntryId, plid}; Long count = (Long)finderCache.getResult( finderPath, finderArgs, this); if (count == null) { StringBundler sb = new StringBundler(4); sb.append(_SQL_COUNT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_F_P_GROUPID_2); sb.append(_FINDER_COLUMN_G_F_P_FRAGMENTENTRYID_2); sb.append(_FINDER_COLUMN_G_F_P_PLID_2); String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(fragmentEntryId); queryPos.add(plid); count = (Long)query.uniqueResult(); finderCache.putResult(finderPath, finderArgs, count); } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return count.intValue(); } } private static final String _FINDER_COLUMN_G_F_P_GROUPID_2 = "fragmentEntryLink.groupId = ? AND "; private static final String _FINDER_COLUMN_G_F_P_FRAGMENTENTRYID_2 = "fragmentEntryLink.fragmentEntryId = ? AND "; private static final String _FINDER_COLUMN_G_F_P_PLID_2 = "fragmentEntryLink.plid = ?"; private FinderPath _finderPathWithPaginationFindByG_S_P; private FinderPath _finderPathWithoutPaginationFindByG_S_P; private FinderPath _finderPathCountByG_S_P; private FinderPath _finderPathWithPaginationCountByG_S_P; /** * Returns all the fragment entry links where groupId = ? and segmentsExperienceId = ? and plid = ?. * * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param plid the plid * @return the matching fragment entry links */ @Override public List findByG_S_P( long groupId, long segmentsExperienceId, long plid) { return findByG_S_P( groupId, segmentsExperienceId, plid, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null); } /** * Returns a range of all the fragment entry links where groupId = ? and segmentsExperienceId = ? and plid = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param plid the plid * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @return the range of matching fragment entry links */ @Override public List findByG_S_P( long groupId, long segmentsExperienceId, long plid, int start, int end) { return findByG_S_P( groupId, segmentsExperienceId, plid, start, end, null); } /** * Returns an ordered range of all the fragment entry links where groupId = ? and segmentsExperienceId = ? and plid = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param plid the plid * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @return the ordered range of matching fragment entry links */ @Override public List findByG_S_P( long groupId, long segmentsExperienceId, long plid, int start, int end, OrderByComparator orderByComparator) { return findByG_S_P( groupId, segmentsExperienceId, plid, start, end, orderByComparator, true); } /** * Returns an ordered range of all the fragment entry links where groupId = ? and segmentsExperienceId = ? and plid = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param plid the plid * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @param useFinderCache whether to use the finder cache * @return the ordered range of matching fragment entry links */ @Override public List findByG_S_P( long groupId, long segmentsExperienceId, long plid, int start, int end, OrderByComparator orderByComparator, boolean useFinderCache) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { FinderPath finderPath = null; Object[] finderArgs = null; if ((start == QueryUtil.ALL_POS) && (end == QueryUtil.ALL_POS) && (orderByComparator == null)) { if (useFinderCache) { finderPath = _finderPathWithoutPaginationFindByG_S_P; finderArgs = new Object[] { groupId, segmentsExperienceId, plid }; } } else if (useFinderCache) { finderPath = _finderPathWithPaginationFindByG_S_P; finderArgs = new Object[] { groupId, segmentsExperienceId, plid, start, end, orderByComparator }; } List list = null; if (useFinderCache) { list = (List)finderCache.getResult( finderPath, finderArgs, this); if ((list != null) && !list.isEmpty()) { for (FragmentEntryLink fragmentEntryLink : list) { if ((groupId != fragmentEntryLink.getGroupId()) || (segmentsExperienceId != fragmentEntryLink.getSegmentsExperienceId()) || (plid != fragmentEntryLink.getPlid())) { list = null; break; } } } } if (list == null) { StringBundler sb = null; if (orderByComparator != null) { sb = new StringBundler( 5 + (orderByComparator.getOrderByFields().length * 2)); } else { sb = new StringBundler(5); } sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_S_P_GROUPID_2); sb.append(_FINDER_COLUMN_G_S_P_SEGMENTSEXPERIENCEID_2); sb.append(_FINDER_COLUMN_G_S_P_PLID_2); if (orderByComparator != null) { appendOrderByComparator( sb, _ORDER_BY_ENTITY_ALIAS, orderByComparator); } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(segmentsExperienceId); queryPos.add(plid); list = (List)QueryUtil.list( query, getDialect(), start, end); cacheResult(list); if (useFinderCache) { finderCache.putResult(finderPath, finderArgs, list); } } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return list; } } /** * Returns the first fragment entry link in the ordered set where groupId = ? and segmentsExperienceId = ? and plid = ?. * * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param plid the plid * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByG_S_P_First( long groupId, long segmentsExperienceId, long plid, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByG_S_P_First( groupId, segmentsExperienceId, plid, orderByComparator); if (fragmentEntryLink != null) { return fragmentEntryLink; } StringBundler sb = new StringBundler(8); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("groupId="); sb.append(groupId); sb.append(", segmentsExperienceId="); sb.append(segmentsExperienceId); sb.append(", plid="); sb.append(plid); sb.append("}"); throw new NoSuchEntryLinkException(sb.toString()); } /** * Returns the first fragment entry link in the ordered set where groupId = ? and segmentsExperienceId = ? and plid = ?. * * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param plid the plid * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByG_S_P_First( long groupId, long segmentsExperienceId, long plid, OrderByComparator orderByComparator) { List list = findByG_S_P( groupId, segmentsExperienceId, plid, 0, 1, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the last fragment entry link in the ordered set where groupId = ? and segmentsExperienceId = ? and plid = ?. * * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param plid the plid * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByG_S_P_Last( long groupId, long segmentsExperienceId, long plid, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByG_S_P_Last( groupId, segmentsExperienceId, plid, orderByComparator); if (fragmentEntryLink != null) { return fragmentEntryLink; } StringBundler sb = new StringBundler(8); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("groupId="); sb.append(groupId); sb.append(", segmentsExperienceId="); sb.append(segmentsExperienceId); sb.append(", plid="); sb.append(plid); sb.append("}"); throw new NoSuchEntryLinkException(sb.toString()); } /** * Returns the last fragment entry link in the ordered set where groupId = ? and segmentsExperienceId = ? and plid = ?. * * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param plid the plid * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByG_S_P_Last( long groupId, long segmentsExperienceId, long plid, OrderByComparator orderByComparator) { int count = countByG_S_P(groupId, segmentsExperienceId, plid); if (count == 0) { return null; } List list = findByG_S_P( groupId, segmentsExperienceId, plid, count - 1, count, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the fragment entry links before and after the current fragment entry link in the ordered set where groupId = ? and segmentsExperienceId = ? and plid = ?. * * @param fragmentEntryLinkId the primary key of the current fragment entry link * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param plid the plid * @param orderByComparator the comparator to order the set by (optionally null) * @return the previous, current, and next fragment entry link * @throws NoSuchEntryLinkException if a fragment entry link with the primary key could not be found */ @Override public FragmentEntryLink[] findByG_S_P_PrevAndNext( long fragmentEntryLinkId, long groupId, long segmentsExperienceId, long plid, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = findByPrimaryKey( fragmentEntryLinkId); Session session = null; try { session = openSession(); FragmentEntryLink[] array = new FragmentEntryLinkImpl[3]; array[0] = getByG_S_P_PrevAndNext( session, fragmentEntryLink, groupId, segmentsExperienceId, plid, orderByComparator, true); array[1] = fragmentEntryLink; array[2] = getByG_S_P_PrevAndNext( session, fragmentEntryLink, groupId, segmentsExperienceId, plid, orderByComparator, false); return array; } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } protected FragmentEntryLink getByG_S_P_PrevAndNext( Session session, FragmentEntryLink fragmentEntryLink, long groupId, long segmentsExperienceId, long plid, OrderByComparator orderByComparator, boolean previous) { StringBundler sb = null; if (orderByComparator != null) { sb = new StringBundler( 6 + (orderByComparator.getOrderByConditionFields().length * 3) + (orderByComparator.getOrderByFields().length * 3)); } else { sb = new StringBundler(5); } sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_S_P_GROUPID_2); sb.append(_FINDER_COLUMN_G_S_P_SEGMENTSEXPERIENCEID_2); sb.append(_FINDER_COLUMN_G_S_P_PLID_2); if (orderByComparator != null) { String[] orderByConditionFields = orderByComparator.getOrderByConditionFields(); if (orderByConditionFields.length > 0) { sb.append(WHERE_AND); } for (int i = 0; i < orderByConditionFields.length; i++) { sb.append(_ORDER_BY_ENTITY_ALIAS); sb.append(orderByConditionFields[i]); if ((i + 1) < orderByConditionFields.length) { if (orderByComparator.isAscending() ^ previous) { sb.append(WHERE_GREATER_THAN_HAS_NEXT); } else { sb.append(WHERE_LESSER_THAN_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { sb.append(WHERE_GREATER_THAN); } else { sb.append(WHERE_LESSER_THAN); } } } sb.append(ORDER_BY_CLAUSE); String[] orderByFields = orderByComparator.getOrderByFields(); for (int i = 0; i < orderByFields.length; i++) { sb.append(_ORDER_BY_ENTITY_ALIAS); sb.append(orderByFields[i]); if ((i + 1) < orderByFields.length) { if (orderByComparator.isAscending() ^ previous) { sb.append(ORDER_BY_ASC_HAS_NEXT); } else { sb.append(ORDER_BY_DESC_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { sb.append(ORDER_BY_ASC); } else { sb.append(ORDER_BY_DESC); } } } } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Query query = session.createQuery(sql); query.setFirstResult(0); query.setMaxResults(2); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(segmentsExperienceId); queryPos.add(plid); if (orderByComparator != null) { for (Object orderByConditionValue : orderByComparator.getOrderByConditionValues( fragmentEntryLink)) { queryPos.add(orderByConditionValue); } } List list = query.list(); if (list.size() == 2) { return list.get(1); } else { return null; } } /** * Returns all the fragment entry links where groupId = ? and segmentsExperienceId = any ? and plid = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param segmentsExperienceIds the segments experience IDs * @param plid the plid * @return the matching fragment entry links */ @Override public List findByG_S_P( long groupId, long[] segmentsExperienceIds, long plid) { return findByG_S_P( groupId, segmentsExperienceIds, plid, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null); } /** * Returns a range of all the fragment entry links where groupId = ? and segmentsExperienceId = any ? and plid = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param segmentsExperienceIds the segments experience IDs * @param plid the plid * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @return the range of matching fragment entry links */ @Override public List findByG_S_P( long groupId, long[] segmentsExperienceIds, long plid, int start, int end) { return findByG_S_P( groupId, segmentsExperienceIds, plid, start, end, null); } /** * Returns an ordered range of all the fragment entry links where groupId = ? and segmentsExperienceId = any ? and plid = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param segmentsExperienceIds the segments experience IDs * @param plid the plid * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @return the ordered range of matching fragment entry links */ @Override public List findByG_S_P( long groupId, long[] segmentsExperienceIds, long plid, int start, int end, OrderByComparator orderByComparator) { return findByG_S_P( groupId, segmentsExperienceIds, plid, start, end, orderByComparator, true); } /** * Returns an ordered range of all the fragment entry links where groupId = ? and segmentsExperienceId = ? and plid = ?, optionally using the finder cache. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param segmentsExperienceIds the segments experience IDs * @param plid the plid * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @param useFinderCache whether to use the finder cache * @return the ordered range of matching fragment entry links */ @Override public List findByG_S_P( long groupId, long[] segmentsExperienceIds, long plid, int start, int end, OrderByComparator orderByComparator, boolean useFinderCache) { if (segmentsExperienceIds == null) { segmentsExperienceIds = new long[0]; } else if (segmentsExperienceIds.length > 1) { segmentsExperienceIds = ArrayUtil.sortedUnique( segmentsExperienceIds); } if (segmentsExperienceIds.length == 1) { return findByG_S_P( groupId, segmentsExperienceIds[0], plid, start, end, orderByComparator); } try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { Object[] finderArgs = null; if ((start == QueryUtil.ALL_POS) && (end == QueryUtil.ALL_POS) && (orderByComparator == null)) { if (useFinderCache) { finderArgs = new Object[] { groupId, StringUtil.merge(segmentsExperienceIds), plid }; } } else if (useFinderCache) { finderArgs = new Object[] { groupId, StringUtil.merge(segmentsExperienceIds), plid, start, end, orderByComparator }; } List list = null; if (useFinderCache) { list = (List)finderCache.getResult( _finderPathWithPaginationFindByG_S_P, finderArgs, this); if ((list != null) && !list.isEmpty()) { for (FragmentEntryLink fragmentEntryLink : list) { if ((groupId != fragmentEntryLink.getGroupId()) || !ArrayUtil.contains( segmentsExperienceIds, fragmentEntryLink.getSegmentsExperienceId()) || (plid != fragmentEntryLink.getPlid())) { list = null; break; } } } } if (list == null) { StringBundler sb = new StringBundler(); sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_S_P_GROUPID_2); if (segmentsExperienceIds.length > 0) { sb.append("("); sb.append(_FINDER_COLUMN_G_S_P_SEGMENTSEXPERIENCEID_7); sb.append(StringUtil.merge(segmentsExperienceIds)); sb.append(")"); sb.append(")"); sb.append(WHERE_AND); } sb.append(_FINDER_COLUMN_G_S_P_PLID_2); sb.setStringAt( removeConjunction(sb.stringAt(sb.index() - 1)), sb.index() - 1); if (orderByComparator != null) { appendOrderByComparator( sb, _ORDER_BY_ENTITY_ALIAS, orderByComparator); } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(plid); list = (List)QueryUtil.list( query, getDialect(), start, end); cacheResult(list); if (useFinderCache) { finderCache.putResult( _finderPathWithPaginationFindByG_S_P, finderArgs, list); } } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return list; } } /** * Removes all the fragment entry links where groupId = ? and segmentsExperienceId = ? and plid = ? from the database. * * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param plid the plid */ @Override public void removeByG_S_P( long groupId, long segmentsExperienceId, long plid) { for (FragmentEntryLink fragmentEntryLink : findByG_S_P( groupId, segmentsExperienceId, plid, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null)) { remove(fragmentEntryLink); } } /** * Returns the number of fragment entry links where groupId = ? and segmentsExperienceId = ? and plid = ?. * * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param plid the plid * @return the number of matching fragment entry links */ @Override public int countByG_S_P( long groupId, long segmentsExperienceId, long plid) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { FinderPath finderPath = _finderPathCountByG_S_P; Object[] finderArgs = new Object[] { groupId, segmentsExperienceId, plid }; Long count = (Long)finderCache.getResult( finderPath, finderArgs, this); if (count == null) { StringBundler sb = new StringBundler(4); sb.append(_SQL_COUNT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_S_P_GROUPID_2); sb.append(_FINDER_COLUMN_G_S_P_SEGMENTSEXPERIENCEID_2); sb.append(_FINDER_COLUMN_G_S_P_PLID_2); String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(segmentsExperienceId); queryPos.add(plid); count = (Long)query.uniqueResult(); finderCache.putResult(finderPath, finderArgs, count); } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return count.intValue(); } } /** * Returns the number of fragment entry links where groupId = ? and segmentsExperienceId = any ? and plid = ?. * * @param groupId the group ID * @param segmentsExperienceIds the segments experience IDs * @param plid the plid * @return the number of matching fragment entry links */ @Override public int countByG_S_P( long groupId, long[] segmentsExperienceIds, long plid) { if (segmentsExperienceIds == null) { segmentsExperienceIds = new long[0]; } else if (segmentsExperienceIds.length > 1) { segmentsExperienceIds = ArrayUtil.sortedUnique( segmentsExperienceIds); } try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { Object[] finderArgs = new Object[] { groupId, StringUtil.merge(segmentsExperienceIds), plid }; Long count = (Long)finderCache.getResult( _finderPathWithPaginationCountByG_S_P, finderArgs, this); if (count == null) { StringBundler sb = new StringBundler(); sb.append(_SQL_COUNT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_S_P_GROUPID_2); if (segmentsExperienceIds.length > 0) { sb.append("("); sb.append(_FINDER_COLUMN_G_S_P_SEGMENTSEXPERIENCEID_7); sb.append(StringUtil.merge(segmentsExperienceIds)); sb.append(")"); sb.append(")"); sb.append(WHERE_AND); } sb.append(_FINDER_COLUMN_G_S_P_PLID_2); sb.setStringAt( removeConjunction(sb.stringAt(sb.index() - 1)), sb.index() - 1); String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(plid); count = (Long)query.uniqueResult(); finderCache.putResult( _finderPathWithPaginationCountByG_S_P, finderArgs, count); } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return count.intValue(); } } private static final String _FINDER_COLUMN_G_S_P_GROUPID_2 = "fragmentEntryLink.groupId = ? AND "; private static final String _FINDER_COLUMN_G_S_P_SEGMENTSEXPERIENCEID_2 = "fragmentEntryLink.segmentsExperienceId = ? AND "; private static final String _FINDER_COLUMN_G_S_P_SEGMENTSEXPERIENCEID_7 = "fragmentEntryLink.segmentsExperienceId IN ("; private static final String _FINDER_COLUMN_G_S_P_PLID_2 = "fragmentEntryLink.plid = ?"; private FinderPath _finderPathWithPaginationFindByG_C_C; private FinderPath _finderPathWithoutPaginationFindByG_C_C; private FinderPath _finderPathCountByG_C_C; /** * Returns all the fragment entry links where groupId = ? and classNameId = ? and classPK = ?. * * @param groupId the group ID * @param classNameId the class name ID * @param classPK the class pk * @return the matching fragment entry links */ @Override public List findByG_C_C( long groupId, long classNameId, long classPK) { return findByG_C_C( groupId, classNameId, classPK, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null); } /** * Returns a range of all the fragment entry links where groupId = ? and classNameId = ? and classPK = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param classNameId the class name ID * @param classPK the class pk * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @return the range of matching fragment entry links */ @Override public List findByG_C_C( long groupId, long classNameId, long classPK, int start, int end) { return findByG_C_C(groupId, classNameId, classPK, start, end, null); } /** * Returns an ordered range of all the fragment entry links where groupId = ? and classNameId = ? and classPK = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param classNameId the class name ID * @param classPK the class pk * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @return the ordered range of matching fragment entry links */ @Override public List findByG_C_C( long groupId, long classNameId, long classPK, int start, int end, OrderByComparator orderByComparator) { return findByG_C_C( groupId, classNameId, classPK, start, end, orderByComparator, true); } /** * Returns an ordered range of all the fragment entry links where groupId = ? and classNameId = ? and classPK = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param classNameId the class name ID * @param classPK the class pk * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @param useFinderCache whether to use the finder cache * @return the ordered range of matching fragment entry links */ @Override public List findByG_C_C( long groupId, long classNameId, long classPK, int start, int end, OrderByComparator orderByComparator, boolean useFinderCache) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { FinderPath finderPath = null; Object[] finderArgs = null; if ((start == QueryUtil.ALL_POS) && (end == QueryUtil.ALL_POS) && (orderByComparator == null)) { if (useFinderCache) { finderPath = _finderPathWithoutPaginationFindByG_C_C; finderArgs = new Object[] {groupId, classNameId, classPK}; } } else if (useFinderCache) { finderPath = _finderPathWithPaginationFindByG_C_C; finderArgs = new Object[] { groupId, classNameId, classPK, start, end, orderByComparator }; } List list = null; if (useFinderCache) { list = (List)finderCache.getResult( finderPath, finderArgs, this); if ((list != null) && !list.isEmpty()) { for (FragmentEntryLink fragmentEntryLink : list) { if ((groupId != fragmentEntryLink.getGroupId()) || (classNameId != fragmentEntryLink.getClassNameId()) || (classPK != fragmentEntryLink.getClassPK())) { list = null; break; } } } } if (list == null) { StringBundler sb = null; if (orderByComparator != null) { sb = new StringBundler( 5 + (orderByComparator.getOrderByFields().length * 2)); } else { sb = new StringBundler(5); } sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_C_C_GROUPID_2); sb.append(_FINDER_COLUMN_G_C_C_CLASSNAMEID_2); sb.append(_FINDER_COLUMN_G_C_C_CLASSPK_2); if (orderByComparator != null) { appendOrderByComparator( sb, _ORDER_BY_ENTITY_ALIAS, orderByComparator); } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(classNameId); queryPos.add(classPK); list = (List)QueryUtil.list( query, getDialect(), start, end); cacheResult(list); if (useFinderCache) { finderCache.putResult(finderPath, finderArgs, list); } } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return list; } } /** * Returns the first fragment entry link in the ordered set where groupId = ? and classNameId = ? and classPK = ?. * * @param groupId the group ID * @param classNameId the class name ID * @param classPK the class pk * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByG_C_C_First( long groupId, long classNameId, long classPK, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByG_C_C_First( groupId, classNameId, classPK, orderByComparator); if (fragmentEntryLink != null) { return fragmentEntryLink; } StringBundler sb = new StringBundler(8); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("groupId="); sb.append(groupId); sb.append(", classNameId="); sb.append(classNameId); sb.append(", classPK="); sb.append(classPK); sb.append("}"); throw new NoSuchEntryLinkException(sb.toString()); } /** * Returns the first fragment entry link in the ordered set where groupId = ? and classNameId = ? and classPK = ?. * * @param groupId the group ID * @param classNameId the class name ID * @param classPK the class pk * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByG_C_C_First( long groupId, long classNameId, long classPK, OrderByComparator orderByComparator) { List list = findByG_C_C( groupId, classNameId, classPK, 0, 1, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the last fragment entry link in the ordered set where groupId = ? and classNameId = ? and classPK = ?. * * @param groupId the group ID * @param classNameId the class name ID * @param classPK the class pk * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByG_C_C_Last( long groupId, long classNameId, long classPK, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByG_C_C_Last( groupId, classNameId, classPK, orderByComparator); if (fragmentEntryLink != null) { return fragmentEntryLink; } StringBundler sb = new StringBundler(8); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("groupId="); sb.append(groupId); sb.append(", classNameId="); sb.append(classNameId); sb.append(", classPK="); sb.append(classPK); sb.append("}"); throw new NoSuchEntryLinkException(sb.toString()); } /** * Returns the last fragment entry link in the ordered set where groupId = ? and classNameId = ? and classPK = ?. * * @param groupId the group ID * @param classNameId the class name ID * @param classPK the class pk * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByG_C_C_Last( long groupId, long classNameId, long classPK, OrderByComparator orderByComparator) { int count = countByG_C_C(groupId, classNameId, classPK); if (count == 0) { return null; } List list = findByG_C_C( groupId, classNameId, classPK, count - 1, count, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the fragment entry links before and after the current fragment entry link in the ordered set where groupId = ? and classNameId = ? and classPK = ?. * * @param fragmentEntryLinkId the primary key of the current fragment entry link * @param groupId the group ID * @param classNameId the class name ID * @param classPK the class pk * @param orderByComparator the comparator to order the set by (optionally null) * @return the previous, current, and next fragment entry link * @throws NoSuchEntryLinkException if a fragment entry link with the primary key could not be found */ @Override public FragmentEntryLink[] findByG_C_C_PrevAndNext( long fragmentEntryLinkId, long groupId, long classNameId, long classPK, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = findByPrimaryKey( fragmentEntryLinkId); Session session = null; try { session = openSession(); FragmentEntryLink[] array = new FragmentEntryLinkImpl[3]; array[0] = getByG_C_C_PrevAndNext( session, fragmentEntryLink, groupId, classNameId, classPK, orderByComparator, true); array[1] = fragmentEntryLink; array[2] = getByG_C_C_PrevAndNext( session, fragmentEntryLink, groupId, classNameId, classPK, orderByComparator, false); return array; } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } protected FragmentEntryLink getByG_C_C_PrevAndNext( Session session, FragmentEntryLink fragmentEntryLink, long groupId, long classNameId, long classPK, OrderByComparator orderByComparator, boolean previous) { StringBundler sb = null; if (orderByComparator != null) { sb = new StringBundler( 6 + (orderByComparator.getOrderByConditionFields().length * 3) + (orderByComparator.getOrderByFields().length * 3)); } else { sb = new StringBundler(5); } sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_C_C_GROUPID_2); sb.append(_FINDER_COLUMN_G_C_C_CLASSNAMEID_2); sb.append(_FINDER_COLUMN_G_C_C_CLASSPK_2); if (orderByComparator != null) { String[] orderByConditionFields = orderByComparator.getOrderByConditionFields(); if (orderByConditionFields.length > 0) { sb.append(WHERE_AND); } for (int i = 0; i < orderByConditionFields.length; i++) { sb.append(_ORDER_BY_ENTITY_ALIAS); sb.append(orderByConditionFields[i]); if ((i + 1) < orderByConditionFields.length) { if (orderByComparator.isAscending() ^ previous) { sb.append(WHERE_GREATER_THAN_HAS_NEXT); } else { sb.append(WHERE_LESSER_THAN_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { sb.append(WHERE_GREATER_THAN); } else { sb.append(WHERE_LESSER_THAN); } } } sb.append(ORDER_BY_CLAUSE); String[] orderByFields = orderByComparator.getOrderByFields(); for (int i = 0; i < orderByFields.length; i++) { sb.append(_ORDER_BY_ENTITY_ALIAS); sb.append(orderByFields[i]); if ((i + 1) < orderByFields.length) { if (orderByComparator.isAscending() ^ previous) { sb.append(ORDER_BY_ASC_HAS_NEXT); } else { sb.append(ORDER_BY_DESC_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { sb.append(ORDER_BY_ASC); } else { sb.append(ORDER_BY_DESC); } } } } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Query query = session.createQuery(sql); query.setFirstResult(0); query.setMaxResults(2); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(classNameId); queryPos.add(classPK); if (orderByComparator != null) { for (Object orderByConditionValue : orderByComparator.getOrderByConditionValues( fragmentEntryLink)) { queryPos.add(orderByConditionValue); } } List list = query.list(); if (list.size() == 2) { return list.get(1); } else { return null; } } /** * Removes all the fragment entry links where groupId = ? and classNameId = ? and classPK = ? from the database. * * @param groupId the group ID * @param classNameId the class name ID * @param classPK the class pk */ @Override public void removeByG_C_C(long groupId, long classNameId, long classPK) { for (FragmentEntryLink fragmentEntryLink : findByG_C_C( groupId, classNameId, classPK, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null)) { remove(fragmentEntryLink); } } /** * Returns the number of fragment entry links where groupId = ? and classNameId = ? and classPK = ?. * * @param groupId the group ID * @param classNameId the class name ID * @param classPK the class pk * @return the number of matching fragment entry links */ @Override public int countByG_C_C(long groupId, long classNameId, long classPK) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { FinderPath finderPath = _finderPathCountByG_C_C; Object[] finderArgs = new Object[] {groupId, classNameId, classPK}; Long count = (Long)finderCache.getResult( finderPath, finderArgs, this); if (count == null) { StringBundler sb = new StringBundler(4); sb.append(_SQL_COUNT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_C_C_GROUPID_2); sb.append(_FINDER_COLUMN_G_C_C_CLASSNAMEID_2); sb.append(_FINDER_COLUMN_G_C_C_CLASSPK_2); String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(classNameId); queryPos.add(classPK); count = (Long)query.uniqueResult(); finderCache.putResult(finderPath, finderArgs, count); } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return count.intValue(); } } private static final String _FINDER_COLUMN_G_C_C_GROUPID_2 = "fragmentEntryLink.groupId = ? AND "; private static final String _FINDER_COLUMN_G_C_C_CLASSNAMEID_2 = "fragmentEntryLink.classNameId = ? AND "; private static final String _FINDER_COLUMN_G_C_C_CLASSPK_2 = "fragmentEntryLink.classPK = ?"; private FinderPath _finderPathWithPaginationFindByG_P_D; private FinderPath _finderPathWithoutPaginationFindByG_P_D; private FinderPath _finderPathCountByG_P_D; /** * Returns all the fragment entry links where groupId = ? and plid = ? and deleted = ?. * * @param groupId the group ID * @param plid the plid * @param deleted the deleted * @return the matching fragment entry links */ @Override public List findByG_P_D( long groupId, long plid, boolean deleted) { return findByG_P_D( groupId, plid, deleted, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null); } /** * Returns a range of all the fragment entry links where groupId = ? and plid = ? and deleted = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param plid the plid * @param deleted the deleted * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @return the range of matching fragment entry links */ @Override public List findByG_P_D( long groupId, long plid, boolean deleted, int start, int end) { return findByG_P_D(groupId, plid, deleted, start, end, null); } /** * Returns an ordered range of all the fragment entry links where groupId = ? and plid = ? and deleted = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param plid the plid * @param deleted the deleted * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @return the ordered range of matching fragment entry links */ @Override public List findByG_P_D( long groupId, long plid, boolean deleted, int start, int end, OrderByComparator orderByComparator) { return findByG_P_D( groupId, plid, deleted, start, end, orderByComparator, true); } /** * Returns an ordered range of all the fragment entry links where groupId = ? and plid = ? and deleted = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param plid the plid * @param deleted the deleted * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @param useFinderCache whether to use the finder cache * @return the ordered range of matching fragment entry links */ @Override public List findByG_P_D( long groupId, long plid, boolean deleted, int start, int end, OrderByComparator orderByComparator, boolean useFinderCache) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { FinderPath finderPath = null; Object[] finderArgs = null; if ((start == QueryUtil.ALL_POS) && (end == QueryUtil.ALL_POS) && (orderByComparator == null)) { if (useFinderCache) { finderPath = _finderPathWithoutPaginationFindByG_P_D; finderArgs = new Object[] {groupId, plid, deleted}; } } else if (useFinderCache) { finderPath = _finderPathWithPaginationFindByG_P_D; finderArgs = new Object[] { groupId, plid, deleted, start, end, orderByComparator }; } List list = null; if (useFinderCache) { list = (List)finderCache.getResult( finderPath, finderArgs, this); if ((list != null) && !list.isEmpty()) { for (FragmentEntryLink fragmentEntryLink : list) { if ((groupId != fragmentEntryLink.getGroupId()) || (plid != fragmentEntryLink.getPlid()) || (deleted != fragmentEntryLink.isDeleted())) { list = null; break; } } } } if (list == null) { StringBundler sb = null; if (orderByComparator != null) { sb = new StringBundler( 5 + (orderByComparator.getOrderByFields().length * 2)); } else { sb = new StringBundler(5); } sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_P_D_GROUPID_2); sb.append(_FINDER_COLUMN_G_P_D_PLID_2); sb.append(_FINDER_COLUMN_G_P_D_DELETED_2); if (orderByComparator != null) { appendOrderByComparator( sb, _ORDER_BY_ENTITY_ALIAS, orderByComparator); } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(plid); queryPos.add(deleted); list = (List)QueryUtil.list( query, getDialect(), start, end); cacheResult(list); if (useFinderCache) { finderCache.putResult(finderPath, finderArgs, list); } } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return list; } } /** * Returns the first fragment entry link in the ordered set where groupId = ? and plid = ? and deleted = ?. * * @param groupId the group ID * @param plid the plid * @param deleted the deleted * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByG_P_D_First( long groupId, long plid, boolean deleted, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByG_P_D_First( groupId, plid, deleted, orderByComparator); if (fragmentEntryLink != null) { return fragmentEntryLink; } StringBundler sb = new StringBundler(8); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("groupId="); sb.append(groupId); sb.append(", plid="); sb.append(plid); sb.append(", deleted="); sb.append(deleted); sb.append("}"); throw new NoSuchEntryLinkException(sb.toString()); } /** * Returns the first fragment entry link in the ordered set where groupId = ? and plid = ? and deleted = ?. * * @param groupId the group ID * @param plid the plid * @param deleted the deleted * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByG_P_D_First( long groupId, long plid, boolean deleted, OrderByComparator orderByComparator) { List list = findByG_P_D( groupId, plid, deleted, 0, 1, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the last fragment entry link in the ordered set where groupId = ? and plid = ? and deleted = ?. * * @param groupId the group ID * @param plid the plid * @param deleted the deleted * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByG_P_D_Last( long groupId, long plid, boolean deleted, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByG_P_D_Last( groupId, plid, deleted, orderByComparator); if (fragmentEntryLink != null) { return fragmentEntryLink; } StringBundler sb = new StringBundler(8); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("groupId="); sb.append(groupId); sb.append(", plid="); sb.append(plid); sb.append(", deleted="); sb.append(deleted); sb.append("}"); throw new NoSuchEntryLinkException(sb.toString()); } /** * Returns the last fragment entry link in the ordered set where groupId = ? and plid = ? and deleted = ?. * * @param groupId the group ID * @param plid the plid * @param deleted the deleted * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByG_P_D_Last( long groupId, long plid, boolean deleted, OrderByComparator orderByComparator) { int count = countByG_P_D(groupId, plid, deleted); if (count == 0) { return null; } List list = findByG_P_D( groupId, plid, deleted, count - 1, count, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the fragment entry links before and after the current fragment entry link in the ordered set where groupId = ? and plid = ? and deleted = ?. * * @param fragmentEntryLinkId the primary key of the current fragment entry link * @param groupId the group ID * @param plid the plid * @param deleted the deleted * @param orderByComparator the comparator to order the set by (optionally null) * @return the previous, current, and next fragment entry link * @throws NoSuchEntryLinkException if a fragment entry link with the primary key could not be found */ @Override public FragmentEntryLink[] findByG_P_D_PrevAndNext( long fragmentEntryLinkId, long groupId, long plid, boolean deleted, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = findByPrimaryKey( fragmentEntryLinkId); Session session = null; try { session = openSession(); FragmentEntryLink[] array = new FragmentEntryLinkImpl[3]; array[0] = getByG_P_D_PrevAndNext( session, fragmentEntryLink, groupId, plid, deleted, orderByComparator, true); array[1] = fragmentEntryLink; array[2] = getByG_P_D_PrevAndNext( session, fragmentEntryLink, groupId, plid, deleted, orderByComparator, false); return array; } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } protected FragmentEntryLink getByG_P_D_PrevAndNext( Session session, FragmentEntryLink fragmentEntryLink, long groupId, long plid, boolean deleted, OrderByComparator orderByComparator, boolean previous) { StringBundler sb = null; if (orderByComparator != null) { sb = new StringBundler( 6 + (orderByComparator.getOrderByConditionFields().length * 3) + (orderByComparator.getOrderByFields().length * 3)); } else { sb = new StringBundler(5); } sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_P_D_GROUPID_2); sb.append(_FINDER_COLUMN_G_P_D_PLID_2); sb.append(_FINDER_COLUMN_G_P_D_DELETED_2); if (orderByComparator != null) { String[] orderByConditionFields = orderByComparator.getOrderByConditionFields(); if (orderByConditionFields.length > 0) { sb.append(WHERE_AND); } for (int i = 0; i < orderByConditionFields.length; i++) { sb.append(_ORDER_BY_ENTITY_ALIAS); sb.append(orderByConditionFields[i]); if ((i + 1) < orderByConditionFields.length) { if (orderByComparator.isAscending() ^ previous) { sb.append(WHERE_GREATER_THAN_HAS_NEXT); } else { sb.append(WHERE_LESSER_THAN_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { sb.append(WHERE_GREATER_THAN); } else { sb.append(WHERE_LESSER_THAN); } } } sb.append(ORDER_BY_CLAUSE); String[] orderByFields = orderByComparator.getOrderByFields(); for (int i = 0; i < orderByFields.length; i++) { sb.append(_ORDER_BY_ENTITY_ALIAS); sb.append(orderByFields[i]); if ((i + 1) < orderByFields.length) { if (orderByComparator.isAscending() ^ previous) { sb.append(ORDER_BY_ASC_HAS_NEXT); } else { sb.append(ORDER_BY_DESC_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { sb.append(ORDER_BY_ASC); } else { sb.append(ORDER_BY_DESC); } } } } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Query query = session.createQuery(sql); query.setFirstResult(0); query.setMaxResults(2); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(plid); queryPos.add(deleted); if (orderByComparator != null) { for (Object orderByConditionValue : orderByComparator.getOrderByConditionValues( fragmentEntryLink)) { queryPos.add(orderByConditionValue); } } List list = query.list(); if (list.size() == 2) { return list.get(1); } else { return null; } } /** * Removes all the fragment entry links where groupId = ? and plid = ? and deleted = ? from the database. * * @param groupId the group ID * @param plid the plid * @param deleted the deleted */ @Override public void removeByG_P_D(long groupId, long plid, boolean deleted) { for (FragmentEntryLink fragmentEntryLink : findByG_P_D( groupId, plid, deleted, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null)) { remove(fragmentEntryLink); } } /** * Returns the number of fragment entry links where groupId = ? and plid = ? and deleted = ?. * * @param groupId the group ID * @param plid the plid * @param deleted the deleted * @return the number of matching fragment entry links */ @Override public int countByG_P_D(long groupId, long plid, boolean deleted) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { FinderPath finderPath = _finderPathCountByG_P_D; Object[] finderArgs = new Object[] {groupId, plid, deleted}; Long count = (Long)finderCache.getResult( finderPath, finderArgs, this); if (count == null) { StringBundler sb = new StringBundler(4); sb.append(_SQL_COUNT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_P_D_GROUPID_2); sb.append(_FINDER_COLUMN_G_P_D_PLID_2); sb.append(_FINDER_COLUMN_G_P_D_DELETED_2); String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(plid); queryPos.add(deleted); count = (Long)query.uniqueResult(); finderCache.putResult(finderPath, finderArgs, count); } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return count.intValue(); } } private static final String _FINDER_COLUMN_G_P_D_GROUPID_2 = "fragmentEntryLink.groupId = ? AND "; private static final String _FINDER_COLUMN_G_P_D_PLID_2 = "fragmentEntryLink.plid = ? AND "; private static final String _FINDER_COLUMN_G_P_D_DELETED_2 = "fragmentEntryLink.deleted = ?"; private FinderPath _finderPathWithPaginationFindByG_F_C_C; private FinderPath _finderPathWithoutPaginationFindByG_F_C_C; private FinderPath _finderPathCountByG_F_C_C; /** * Returns all the fragment entry links where groupId = ? and fragmentEntryId = ? and classNameId = ? and classPK = ?. * * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param classNameId the class name ID * @param classPK the class pk * @return the matching fragment entry links */ @Override public List findByG_F_C_C( long groupId, long fragmentEntryId, long classNameId, long classPK) { return findByG_F_C_C( groupId, fragmentEntryId, classNameId, classPK, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null); } /** * Returns a range of all the fragment entry links where groupId = ? and fragmentEntryId = ? and classNameId = ? and classPK = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param classNameId the class name ID * @param classPK the class pk * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @return the range of matching fragment entry links */ @Override public List findByG_F_C_C( long groupId, long fragmentEntryId, long classNameId, long classPK, int start, int end) { return findByG_F_C_C( groupId, fragmentEntryId, classNameId, classPK, start, end, null); } /** * Returns an ordered range of all the fragment entry links where groupId = ? and fragmentEntryId = ? and classNameId = ? and classPK = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param classNameId the class name ID * @param classPK the class pk * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @return the ordered range of matching fragment entry links */ @Override public List findByG_F_C_C( long groupId, long fragmentEntryId, long classNameId, long classPK, int start, int end, OrderByComparator orderByComparator) { return findByG_F_C_C( groupId, fragmentEntryId, classNameId, classPK, start, end, orderByComparator, true); } /** * Returns an ordered range of all the fragment entry links where groupId = ? and fragmentEntryId = ? and classNameId = ? and classPK = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param classNameId the class name ID * @param classPK the class pk * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @param useFinderCache whether to use the finder cache * @return the ordered range of matching fragment entry links */ @Override public List findByG_F_C_C( long groupId, long fragmentEntryId, long classNameId, long classPK, int start, int end, OrderByComparator orderByComparator, boolean useFinderCache) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { FinderPath finderPath = null; Object[] finderArgs = null; if ((start == QueryUtil.ALL_POS) && (end == QueryUtil.ALL_POS) && (orderByComparator == null)) { if (useFinderCache) { finderPath = _finderPathWithoutPaginationFindByG_F_C_C; finderArgs = new Object[] { groupId, fragmentEntryId, classNameId, classPK }; } } else if (useFinderCache) { finderPath = _finderPathWithPaginationFindByG_F_C_C; finderArgs = new Object[] { groupId, fragmentEntryId, classNameId, classPK, start, end, orderByComparator }; } List list = null; if (useFinderCache) { list = (List)finderCache.getResult( finderPath, finderArgs, this); if ((list != null) && !list.isEmpty()) { for (FragmentEntryLink fragmentEntryLink : list) { if ((groupId != fragmentEntryLink.getGroupId()) || (fragmentEntryId != fragmentEntryLink.getFragmentEntryId()) || (classNameId != fragmentEntryLink.getClassNameId()) || (classPK != fragmentEntryLink.getClassPK())) { list = null; break; } } } } if (list == null) { StringBundler sb = null; if (orderByComparator != null) { sb = new StringBundler( 6 + (orderByComparator.getOrderByFields().length * 2)); } else { sb = new StringBundler(6); } sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_F_C_C_GROUPID_2); sb.append(_FINDER_COLUMN_G_F_C_C_FRAGMENTENTRYID_2); sb.append(_FINDER_COLUMN_G_F_C_C_CLASSNAMEID_2); sb.append(_FINDER_COLUMN_G_F_C_C_CLASSPK_2); if (orderByComparator != null) { appendOrderByComparator( sb, _ORDER_BY_ENTITY_ALIAS, orderByComparator); } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(fragmentEntryId); queryPos.add(classNameId); queryPos.add(classPK); list = (List)QueryUtil.list( query, getDialect(), start, end); cacheResult(list); if (useFinderCache) { finderCache.putResult(finderPath, finderArgs, list); } } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return list; } } /** * Returns the first fragment entry link in the ordered set where groupId = ? and fragmentEntryId = ? and classNameId = ? and classPK = ?. * * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param classNameId the class name ID * @param classPK the class pk * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByG_F_C_C_First( long groupId, long fragmentEntryId, long classNameId, long classPK, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByG_F_C_C_First( groupId, fragmentEntryId, classNameId, classPK, orderByComparator); if (fragmentEntryLink != null) { return fragmentEntryLink; } StringBundler sb = new StringBundler(10); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("groupId="); sb.append(groupId); sb.append(", fragmentEntryId="); sb.append(fragmentEntryId); sb.append(", classNameId="); sb.append(classNameId); sb.append(", classPK="); sb.append(classPK); sb.append("}"); throw new NoSuchEntryLinkException(sb.toString()); } /** * Returns the first fragment entry link in the ordered set where groupId = ? and fragmentEntryId = ? and classNameId = ? and classPK = ?. * * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param classNameId the class name ID * @param classPK the class pk * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByG_F_C_C_First( long groupId, long fragmentEntryId, long classNameId, long classPK, OrderByComparator orderByComparator) { List list = findByG_F_C_C( groupId, fragmentEntryId, classNameId, classPK, 0, 1, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the last fragment entry link in the ordered set where groupId = ? and fragmentEntryId = ? and classNameId = ? and classPK = ?. * * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param classNameId the class name ID * @param classPK the class pk * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByG_F_C_C_Last( long groupId, long fragmentEntryId, long classNameId, long classPK, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByG_F_C_C_Last( groupId, fragmentEntryId, classNameId, classPK, orderByComparator); if (fragmentEntryLink != null) { return fragmentEntryLink; } StringBundler sb = new StringBundler(10); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("groupId="); sb.append(groupId); sb.append(", fragmentEntryId="); sb.append(fragmentEntryId); sb.append(", classNameId="); sb.append(classNameId); sb.append(", classPK="); sb.append(classPK); sb.append("}"); throw new NoSuchEntryLinkException(sb.toString()); } /** * Returns the last fragment entry link in the ordered set where groupId = ? and fragmentEntryId = ? and classNameId = ? and classPK = ?. * * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param classNameId the class name ID * @param classPK the class pk * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByG_F_C_C_Last( long groupId, long fragmentEntryId, long classNameId, long classPK, OrderByComparator orderByComparator) { int count = countByG_F_C_C( groupId, fragmentEntryId, classNameId, classPK); if (count == 0) { return null; } List list = findByG_F_C_C( groupId, fragmentEntryId, classNameId, classPK, count - 1, count, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the fragment entry links before and after the current fragment entry link in the ordered set where groupId = ? and fragmentEntryId = ? and classNameId = ? and classPK = ?. * * @param fragmentEntryLinkId the primary key of the current fragment entry link * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param classNameId the class name ID * @param classPK the class pk * @param orderByComparator the comparator to order the set by (optionally null) * @return the previous, current, and next fragment entry link * @throws NoSuchEntryLinkException if a fragment entry link with the primary key could not be found */ @Override public FragmentEntryLink[] findByG_F_C_C_PrevAndNext( long fragmentEntryLinkId, long groupId, long fragmentEntryId, long classNameId, long classPK, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = findByPrimaryKey( fragmentEntryLinkId); Session session = null; try { session = openSession(); FragmentEntryLink[] array = new FragmentEntryLinkImpl[3]; array[0] = getByG_F_C_C_PrevAndNext( session, fragmentEntryLink, groupId, fragmentEntryId, classNameId, classPK, orderByComparator, true); array[1] = fragmentEntryLink; array[2] = getByG_F_C_C_PrevAndNext( session, fragmentEntryLink, groupId, fragmentEntryId, classNameId, classPK, orderByComparator, false); return array; } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } protected FragmentEntryLink getByG_F_C_C_PrevAndNext( Session session, FragmentEntryLink fragmentEntryLink, long groupId, long fragmentEntryId, long classNameId, long classPK, OrderByComparator orderByComparator, boolean previous) { StringBundler sb = null; if (orderByComparator != null) { sb = new StringBundler( 7 + (orderByComparator.getOrderByConditionFields().length * 3) + (orderByComparator.getOrderByFields().length * 3)); } else { sb = new StringBundler(6); } sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_F_C_C_GROUPID_2); sb.append(_FINDER_COLUMN_G_F_C_C_FRAGMENTENTRYID_2); sb.append(_FINDER_COLUMN_G_F_C_C_CLASSNAMEID_2); sb.append(_FINDER_COLUMN_G_F_C_C_CLASSPK_2); if (orderByComparator != null) { String[] orderByConditionFields = orderByComparator.getOrderByConditionFields(); if (orderByConditionFields.length > 0) { sb.append(WHERE_AND); } for (int i = 0; i < orderByConditionFields.length; i++) { sb.append(_ORDER_BY_ENTITY_ALIAS); sb.append(orderByConditionFields[i]); if ((i + 1) < orderByConditionFields.length) { if (orderByComparator.isAscending() ^ previous) { sb.append(WHERE_GREATER_THAN_HAS_NEXT); } else { sb.append(WHERE_LESSER_THAN_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { sb.append(WHERE_GREATER_THAN); } else { sb.append(WHERE_LESSER_THAN); } } } sb.append(ORDER_BY_CLAUSE); String[] orderByFields = orderByComparator.getOrderByFields(); for (int i = 0; i < orderByFields.length; i++) { sb.append(_ORDER_BY_ENTITY_ALIAS); sb.append(orderByFields[i]); if ((i + 1) < orderByFields.length) { if (orderByComparator.isAscending() ^ previous) { sb.append(ORDER_BY_ASC_HAS_NEXT); } else { sb.append(ORDER_BY_DESC_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { sb.append(ORDER_BY_ASC); } else { sb.append(ORDER_BY_DESC); } } } } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Query query = session.createQuery(sql); query.setFirstResult(0); query.setMaxResults(2); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(fragmentEntryId); queryPos.add(classNameId); queryPos.add(classPK); if (orderByComparator != null) { for (Object orderByConditionValue : orderByComparator.getOrderByConditionValues( fragmentEntryLink)) { queryPos.add(orderByConditionValue); } } List list = query.list(); if (list.size() == 2) { return list.get(1); } else { return null; } } /** * Removes all the fragment entry links where groupId = ? and fragmentEntryId = ? and classNameId = ? and classPK = ? from the database. * * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param classNameId the class name ID * @param classPK the class pk */ @Override public void removeByG_F_C_C( long groupId, long fragmentEntryId, long classNameId, long classPK) { for (FragmentEntryLink fragmentEntryLink : findByG_F_C_C( groupId, fragmentEntryId, classNameId, classPK, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null)) { remove(fragmentEntryLink); } } /** * Returns the number of fragment entry links where groupId = ? and fragmentEntryId = ? and classNameId = ? and classPK = ?. * * @param groupId the group ID * @param fragmentEntryId the fragment entry ID * @param classNameId the class name ID * @param classPK the class pk * @return the number of matching fragment entry links */ @Override public int countByG_F_C_C( long groupId, long fragmentEntryId, long classNameId, long classPK) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { FinderPath finderPath = _finderPathCountByG_F_C_C; Object[] finderArgs = new Object[] { groupId, fragmentEntryId, classNameId, classPK }; Long count = (Long)finderCache.getResult( finderPath, finderArgs, this); if (count == null) { StringBundler sb = new StringBundler(5); sb.append(_SQL_COUNT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_F_C_C_GROUPID_2); sb.append(_FINDER_COLUMN_G_F_C_C_FRAGMENTENTRYID_2); sb.append(_FINDER_COLUMN_G_F_C_C_CLASSNAMEID_2); sb.append(_FINDER_COLUMN_G_F_C_C_CLASSPK_2); String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(fragmentEntryId); queryPos.add(classNameId); queryPos.add(classPK); count = (Long)query.uniqueResult(); finderCache.putResult(finderPath, finderArgs, count); } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return count.intValue(); } } private static final String _FINDER_COLUMN_G_F_C_C_GROUPID_2 = "fragmentEntryLink.groupId = ? AND "; private static final String _FINDER_COLUMN_G_F_C_C_FRAGMENTENTRYID_2 = "fragmentEntryLink.fragmentEntryId = ? AND "; private static final String _FINDER_COLUMN_G_F_C_C_CLASSNAMEID_2 = "fragmentEntryLink.classNameId = ? AND "; private static final String _FINDER_COLUMN_G_F_C_C_CLASSPK_2 = "fragmentEntryLink.classPK = ?"; private FinderPath _finderPathWithPaginationFindByG_S_C_C; private FinderPath _finderPathWithoutPaginationFindByG_S_C_C; private FinderPath _finderPathCountByG_S_C_C; /** * Returns all the fragment entry links where groupId = ? and segmentsExperienceId = ? and classNameId = ? and classPK = ?. * * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param classNameId the class name ID * @param classPK the class pk * @return the matching fragment entry links */ @Override public List findByG_S_C_C( long groupId, long segmentsExperienceId, long classNameId, long classPK) { return findByG_S_C_C( groupId, segmentsExperienceId, classNameId, classPK, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null); } /** * Returns a range of all the fragment entry links where groupId = ? and segmentsExperienceId = ? and classNameId = ? and classPK = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param classNameId the class name ID * @param classPK the class pk * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @return the range of matching fragment entry links */ @Override public List findByG_S_C_C( long groupId, long segmentsExperienceId, long classNameId, long classPK, int start, int end) { return findByG_S_C_C( groupId, segmentsExperienceId, classNameId, classPK, start, end, null); } /** * Returns an ordered range of all the fragment entry links where groupId = ? and segmentsExperienceId = ? and classNameId = ? and classPK = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param classNameId the class name ID * @param classPK the class pk * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @return the ordered range of matching fragment entry links */ @Override public List findByG_S_C_C( long groupId, long segmentsExperienceId, long classNameId, long classPK, int start, int end, OrderByComparator orderByComparator) { return findByG_S_C_C( groupId, segmentsExperienceId, classNameId, classPK, start, end, orderByComparator, true); } /** * Returns an ordered range of all the fragment entry links where groupId = ? and segmentsExperienceId = ? and classNameId = ? and classPK = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param classNameId the class name ID * @param classPK the class pk * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @param useFinderCache whether to use the finder cache * @return the ordered range of matching fragment entry links */ @Override public List findByG_S_C_C( long groupId, long segmentsExperienceId, long classNameId, long classPK, int start, int end, OrderByComparator orderByComparator, boolean useFinderCache) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { FinderPath finderPath = null; Object[] finderArgs = null; if ((start == QueryUtil.ALL_POS) && (end == QueryUtil.ALL_POS) && (orderByComparator == null)) { if (useFinderCache) { finderPath = _finderPathWithoutPaginationFindByG_S_C_C; finderArgs = new Object[] { groupId, segmentsExperienceId, classNameId, classPK }; } } else if (useFinderCache) { finderPath = _finderPathWithPaginationFindByG_S_C_C; finderArgs = new Object[] { groupId, segmentsExperienceId, classNameId, classPK, start, end, orderByComparator }; } List list = null; if (useFinderCache) { list = (List)finderCache.getResult( finderPath, finderArgs, this); if ((list != null) && !list.isEmpty()) { for (FragmentEntryLink fragmentEntryLink : list) { if ((groupId != fragmentEntryLink.getGroupId()) || (segmentsExperienceId != fragmentEntryLink.getSegmentsExperienceId()) || (classNameId != fragmentEntryLink.getClassNameId()) || (classPK != fragmentEntryLink.getClassPK())) { list = null; break; } } } } if (list == null) { StringBundler sb = null; if (orderByComparator != null) { sb = new StringBundler( 6 + (orderByComparator.getOrderByFields().length * 2)); } else { sb = new StringBundler(6); } sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_S_C_C_GROUPID_2); sb.append(_FINDER_COLUMN_G_S_C_C_SEGMENTSEXPERIENCEID_2); sb.append(_FINDER_COLUMN_G_S_C_C_CLASSNAMEID_2); sb.append(_FINDER_COLUMN_G_S_C_C_CLASSPK_2); if (orderByComparator != null) { appendOrderByComparator( sb, _ORDER_BY_ENTITY_ALIAS, orderByComparator); } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(segmentsExperienceId); queryPos.add(classNameId); queryPos.add(classPK); list = (List)QueryUtil.list( query, getDialect(), start, end); cacheResult(list); if (useFinderCache) { finderCache.putResult(finderPath, finderArgs, list); } } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return list; } } /** * Returns the first fragment entry link in the ordered set where groupId = ? and segmentsExperienceId = ? and classNameId = ? and classPK = ?. * * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param classNameId the class name ID * @param classPK the class pk * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByG_S_C_C_First( long groupId, long segmentsExperienceId, long classNameId, long classPK, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByG_S_C_C_First( groupId, segmentsExperienceId, classNameId, classPK, orderByComparator); if (fragmentEntryLink != null) { return fragmentEntryLink; } StringBundler sb = new StringBundler(10); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("groupId="); sb.append(groupId); sb.append(", segmentsExperienceId="); sb.append(segmentsExperienceId); sb.append(", classNameId="); sb.append(classNameId); sb.append(", classPK="); sb.append(classPK); sb.append("}"); throw new NoSuchEntryLinkException(sb.toString()); } /** * Returns the first fragment entry link in the ordered set where groupId = ? and segmentsExperienceId = ? and classNameId = ? and classPK = ?. * * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param classNameId the class name ID * @param classPK the class pk * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByG_S_C_C_First( long groupId, long segmentsExperienceId, long classNameId, long classPK, OrderByComparator orderByComparator) { List list = findByG_S_C_C( groupId, segmentsExperienceId, classNameId, classPK, 0, 1, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the last fragment entry link in the ordered set where groupId = ? and segmentsExperienceId = ? and classNameId = ? and classPK = ?. * * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param classNameId the class name ID * @param classPK the class pk * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByG_S_C_C_Last( long groupId, long segmentsExperienceId, long classNameId, long classPK, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByG_S_C_C_Last( groupId, segmentsExperienceId, classNameId, classPK, orderByComparator); if (fragmentEntryLink != null) { return fragmentEntryLink; } StringBundler sb = new StringBundler(10); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("groupId="); sb.append(groupId); sb.append(", segmentsExperienceId="); sb.append(segmentsExperienceId); sb.append(", classNameId="); sb.append(classNameId); sb.append(", classPK="); sb.append(classPK); sb.append("}"); throw new NoSuchEntryLinkException(sb.toString()); } /** * Returns the last fragment entry link in the ordered set where groupId = ? and segmentsExperienceId = ? and classNameId = ? and classPK = ?. * * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param classNameId the class name ID * @param classPK the class pk * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByG_S_C_C_Last( long groupId, long segmentsExperienceId, long classNameId, long classPK, OrderByComparator orderByComparator) { int count = countByG_S_C_C( groupId, segmentsExperienceId, classNameId, classPK); if (count == 0) { return null; } List list = findByG_S_C_C( groupId, segmentsExperienceId, classNameId, classPK, count - 1, count, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the fragment entry links before and after the current fragment entry link in the ordered set where groupId = ? and segmentsExperienceId = ? and classNameId = ? and classPK = ?. * * @param fragmentEntryLinkId the primary key of the current fragment entry link * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param classNameId the class name ID * @param classPK the class pk * @param orderByComparator the comparator to order the set by (optionally null) * @return the previous, current, and next fragment entry link * @throws NoSuchEntryLinkException if a fragment entry link with the primary key could not be found */ @Override public FragmentEntryLink[] findByG_S_C_C_PrevAndNext( long fragmentEntryLinkId, long groupId, long segmentsExperienceId, long classNameId, long classPK, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = findByPrimaryKey( fragmentEntryLinkId); Session session = null; try { session = openSession(); FragmentEntryLink[] array = new FragmentEntryLinkImpl[3]; array[0] = getByG_S_C_C_PrevAndNext( session, fragmentEntryLink, groupId, segmentsExperienceId, classNameId, classPK, orderByComparator, true); array[1] = fragmentEntryLink; array[2] = getByG_S_C_C_PrevAndNext( session, fragmentEntryLink, groupId, segmentsExperienceId, classNameId, classPK, orderByComparator, false); return array; } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } protected FragmentEntryLink getByG_S_C_C_PrevAndNext( Session session, FragmentEntryLink fragmentEntryLink, long groupId, long segmentsExperienceId, long classNameId, long classPK, OrderByComparator orderByComparator, boolean previous) { StringBundler sb = null; if (orderByComparator != null) { sb = new StringBundler( 7 + (orderByComparator.getOrderByConditionFields().length * 3) + (orderByComparator.getOrderByFields().length * 3)); } else { sb = new StringBundler(6); } sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_S_C_C_GROUPID_2); sb.append(_FINDER_COLUMN_G_S_C_C_SEGMENTSEXPERIENCEID_2); sb.append(_FINDER_COLUMN_G_S_C_C_CLASSNAMEID_2); sb.append(_FINDER_COLUMN_G_S_C_C_CLASSPK_2); if (orderByComparator != null) { String[] orderByConditionFields = orderByComparator.getOrderByConditionFields(); if (orderByConditionFields.length > 0) { sb.append(WHERE_AND); } for (int i = 0; i < orderByConditionFields.length; i++) { sb.append(_ORDER_BY_ENTITY_ALIAS); sb.append(orderByConditionFields[i]); if ((i + 1) < orderByConditionFields.length) { if (orderByComparator.isAscending() ^ previous) { sb.append(WHERE_GREATER_THAN_HAS_NEXT); } else { sb.append(WHERE_LESSER_THAN_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { sb.append(WHERE_GREATER_THAN); } else { sb.append(WHERE_LESSER_THAN); } } } sb.append(ORDER_BY_CLAUSE); String[] orderByFields = orderByComparator.getOrderByFields(); for (int i = 0; i < orderByFields.length; i++) { sb.append(_ORDER_BY_ENTITY_ALIAS); sb.append(orderByFields[i]); if ((i + 1) < orderByFields.length) { if (orderByComparator.isAscending() ^ previous) { sb.append(ORDER_BY_ASC_HAS_NEXT); } else { sb.append(ORDER_BY_DESC_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { sb.append(ORDER_BY_ASC); } else { sb.append(ORDER_BY_DESC); } } } } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Query query = session.createQuery(sql); query.setFirstResult(0); query.setMaxResults(2); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(segmentsExperienceId); queryPos.add(classNameId); queryPos.add(classPK); if (orderByComparator != null) { for (Object orderByConditionValue : orderByComparator.getOrderByConditionValues( fragmentEntryLink)) { queryPos.add(orderByConditionValue); } } List list = query.list(); if (list.size() == 2) { return list.get(1); } else { return null; } } /** * Removes all the fragment entry links where groupId = ? and segmentsExperienceId = ? and classNameId = ? and classPK = ? from the database. * * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param classNameId the class name ID * @param classPK the class pk */ @Override public void removeByG_S_C_C( long groupId, long segmentsExperienceId, long classNameId, long classPK) { for (FragmentEntryLink fragmentEntryLink : findByG_S_C_C( groupId, segmentsExperienceId, classNameId, classPK, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null)) { remove(fragmentEntryLink); } } /** * Returns the number of fragment entry links where groupId = ? and segmentsExperienceId = ? and classNameId = ? and classPK = ?. * * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param classNameId the class name ID * @param classPK the class pk * @return the number of matching fragment entry links */ @Override public int countByG_S_C_C( long groupId, long segmentsExperienceId, long classNameId, long classPK) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { FinderPath finderPath = _finderPathCountByG_S_C_C; Object[] finderArgs = new Object[] { groupId, segmentsExperienceId, classNameId, classPK }; Long count = (Long)finderCache.getResult( finderPath, finderArgs, this); if (count == null) { StringBundler sb = new StringBundler(5); sb.append(_SQL_COUNT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_S_C_C_GROUPID_2); sb.append(_FINDER_COLUMN_G_S_C_C_SEGMENTSEXPERIENCEID_2); sb.append(_FINDER_COLUMN_G_S_C_C_CLASSNAMEID_2); sb.append(_FINDER_COLUMN_G_S_C_C_CLASSPK_2); String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(segmentsExperienceId); queryPos.add(classNameId); queryPos.add(classPK); count = (Long)query.uniqueResult(); finderCache.putResult(finderPath, finderArgs, count); } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return count.intValue(); } } private static final String _FINDER_COLUMN_G_S_C_C_GROUPID_2 = "fragmentEntryLink.groupId = ? AND "; private static final String _FINDER_COLUMN_G_S_C_C_SEGMENTSEXPERIENCEID_2 = "fragmentEntryLink.segmentsExperienceId = ? AND "; private static final String _FINDER_COLUMN_G_S_C_C_CLASSNAMEID_2 = "fragmentEntryLink.classNameId = ? AND "; private static final String _FINDER_COLUMN_G_S_C_C_CLASSPK_2 = "fragmentEntryLink.classPK = ?"; private FinderPath _finderPathWithPaginationFindByG_S_P_D; private FinderPath _finderPathWithoutPaginationFindByG_S_P_D; private FinderPath _finderPathCountByG_S_P_D; private FinderPath _finderPathWithPaginationCountByG_S_P_D; /** * Returns all the fragment entry links where groupId = ? and segmentsExperienceId = ? and plid = ? and deleted = ?. * * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param plid the plid * @param deleted the deleted * @return the matching fragment entry links */ @Override public List findByG_S_P_D( long groupId, long segmentsExperienceId, long plid, boolean deleted) { return findByG_S_P_D( groupId, segmentsExperienceId, plid, deleted, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null); } /** * Returns a range of all the fragment entry links where groupId = ? and segmentsExperienceId = ? and plid = ? and deleted = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param plid the plid * @param deleted the deleted * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @return the range of matching fragment entry links */ @Override public List findByG_S_P_D( long groupId, long segmentsExperienceId, long plid, boolean deleted, int start, int end) { return findByG_S_P_D( groupId, segmentsExperienceId, plid, deleted, start, end, null); } /** * Returns an ordered range of all the fragment entry links where groupId = ? and segmentsExperienceId = ? and plid = ? and deleted = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param plid the plid * @param deleted the deleted * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @return the ordered range of matching fragment entry links */ @Override public List findByG_S_P_D( long groupId, long segmentsExperienceId, long plid, boolean deleted, int start, int end, OrderByComparator orderByComparator) { return findByG_S_P_D( groupId, segmentsExperienceId, plid, deleted, start, end, orderByComparator, true); } /** * Returns an ordered range of all the fragment entry links where groupId = ? and segmentsExperienceId = ? and plid = ? and deleted = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param plid the plid * @param deleted the deleted * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @param useFinderCache whether to use the finder cache * @return the ordered range of matching fragment entry links */ @Override public List findByG_S_P_D( long groupId, long segmentsExperienceId, long plid, boolean deleted, int start, int end, OrderByComparator orderByComparator, boolean useFinderCache) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { FinderPath finderPath = null; Object[] finderArgs = null; if ((start == QueryUtil.ALL_POS) && (end == QueryUtil.ALL_POS) && (orderByComparator == null)) { if (useFinderCache) { finderPath = _finderPathWithoutPaginationFindByG_S_P_D; finderArgs = new Object[] { groupId, segmentsExperienceId, plid, deleted }; } } else if (useFinderCache) { finderPath = _finderPathWithPaginationFindByG_S_P_D; finderArgs = new Object[] { groupId, segmentsExperienceId, plid, deleted, start, end, orderByComparator }; } List list = null; if (useFinderCache) { list = (List)finderCache.getResult( finderPath, finderArgs, this); if ((list != null) && !list.isEmpty()) { for (FragmentEntryLink fragmentEntryLink : list) { if ((groupId != fragmentEntryLink.getGroupId()) || (segmentsExperienceId != fragmentEntryLink.getSegmentsExperienceId()) || (plid != fragmentEntryLink.getPlid()) || (deleted != fragmentEntryLink.isDeleted())) { list = null; break; } } } } if (list == null) { StringBundler sb = null; if (orderByComparator != null) { sb = new StringBundler( 6 + (orderByComparator.getOrderByFields().length * 2)); } else { sb = new StringBundler(6); } sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_S_P_D_GROUPID_2); sb.append(_FINDER_COLUMN_G_S_P_D_SEGMENTSEXPERIENCEID_2); sb.append(_FINDER_COLUMN_G_S_P_D_PLID_2); sb.append(_FINDER_COLUMN_G_S_P_D_DELETED_2); if (orderByComparator != null) { appendOrderByComparator( sb, _ORDER_BY_ENTITY_ALIAS, orderByComparator); } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(segmentsExperienceId); queryPos.add(plid); queryPos.add(deleted); list = (List)QueryUtil.list( query, getDialect(), start, end); cacheResult(list); if (useFinderCache) { finderCache.putResult(finderPath, finderArgs, list); } } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return list; } } /** * Returns the first fragment entry link in the ordered set where groupId = ? and segmentsExperienceId = ? and plid = ? and deleted = ?. * * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param plid the plid * @param deleted the deleted * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByG_S_P_D_First( long groupId, long segmentsExperienceId, long plid, boolean deleted, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByG_S_P_D_First( groupId, segmentsExperienceId, plid, deleted, orderByComparator); if (fragmentEntryLink != null) { return fragmentEntryLink; } StringBundler sb = new StringBundler(10); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("groupId="); sb.append(groupId); sb.append(", segmentsExperienceId="); sb.append(segmentsExperienceId); sb.append(", plid="); sb.append(plid); sb.append(", deleted="); sb.append(deleted); sb.append("}"); throw new NoSuchEntryLinkException(sb.toString()); } /** * Returns the first fragment entry link in the ordered set where groupId = ? and segmentsExperienceId = ? and plid = ? and deleted = ?. * * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param plid the plid * @param deleted the deleted * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByG_S_P_D_First( long groupId, long segmentsExperienceId, long plid, boolean deleted, OrderByComparator orderByComparator) { List list = findByG_S_P_D( groupId, segmentsExperienceId, plid, deleted, 0, 1, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the last fragment entry link in the ordered set where groupId = ? and segmentsExperienceId = ? and plid = ? and deleted = ?. * * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param plid the plid * @param deleted the deleted * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByG_S_P_D_Last( long groupId, long segmentsExperienceId, long plid, boolean deleted, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByG_S_P_D_Last( groupId, segmentsExperienceId, plid, deleted, orderByComparator); if (fragmentEntryLink != null) { return fragmentEntryLink; } StringBundler sb = new StringBundler(10); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("groupId="); sb.append(groupId); sb.append(", segmentsExperienceId="); sb.append(segmentsExperienceId); sb.append(", plid="); sb.append(plid); sb.append(", deleted="); sb.append(deleted); sb.append("}"); throw new NoSuchEntryLinkException(sb.toString()); } /** * Returns the last fragment entry link in the ordered set where groupId = ? and segmentsExperienceId = ? and plid = ? and deleted = ?. * * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param plid the plid * @param deleted the deleted * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByG_S_P_D_Last( long groupId, long segmentsExperienceId, long plid, boolean deleted, OrderByComparator orderByComparator) { int count = countByG_S_P_D( groupId, segmentsExperienceId, plid, deleted); if (count == 0) { return null; } List list = findByG_S_P_D( groupId, segmentsExperienceId, plid, deleted, count - 1, count, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the fragment entry links before and after the current fragment entry link in the ordered set where groupId = ? and segmentsExperienceId = ? and plid = ? and deleted = ?. * * @param fragmentEntryLinkId the primary key of the current fragment entry link * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param plid the plid * @param deleted the deleted * @param orderByComparator the comparator to order the set by (optionally null) * @return the previous, current, and next fragment entry link * @throws NoSuchEntryLinkException if a fragment entry link with the primary key could not be found */ @Override public FragmentEntryLink[] findByG_S_P_D_PrevAndNext( long fragmentEntryLinkId, long groupId, long segmentsExperienceId, long plid, boolean deleted, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = findByPrimaryKey( fragmentEntryLinkId); Session session = null; try { session = openSession(); FragmentEntryLink[] array = new FragmentEntryLinkImpl[3]; array[0] = getByG_S_P_D_PrevAndNext( session, fragmentEntryLink, groupId, segmentsExperienceId, plid, deleted, orderByComparator, true); array[1] = fragmentEntryLink; array[2] = getByG_S_P_D_PrevAndNext( session, fragmentEntryLink, groupId, segmentsExperienceId, plid, deleted, orderByComparator, false); return array; } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } protected FragmentEntryLink getByG_S_P_D_PrevAndNext( Session session, FragmentEntryLink fragmentEntryLink, long groupId, long segmentsExperienceId, long plid, boolean deleted, OrderByComparator orderByComparator, boolean previous) { StringBundler sb = null; if (orderByComparator != null) { sb = new StringBundler( 7 + (orderByComparator.getOrderByConditionFields().length * 3) + (orderByComparator.getOrderByFields().length * 3)); } else { sb = new StringBundler(6); } sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_S_P_D_GROUPID_2); sb.append(_FINDER_COLUMN_G_S_P_D_SEGMENTSEXPERIENCEID_2); sb.append(_FINDER_COLUMN_G_S_P_D_PLID_2); sb.append(_FINDER_COLUMN_G_S_P_D_DELETED_2); if (orderByComparator != null) { String[] orderByConditionFields = orderByComparator.getOrderByConditionFields(); if (orderByConditionFields.length > 0) { sb.append(WHERE_AND); } for (int i = 0; i < orderByConditionFields.length; i++) { sb.append(_ORDER_BY_ENTITY_ALIAS); sb.append(orderByConditionFields[i]); if ((i + 1) < orderByConditionFields.length) { if (orderByComparator.isAscending() ^ previous) { sb.append(WHERE_GREATER_THAN_HAS_NEXT); } else { sb.append(WHERE_LESSER_THAN_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { sb.append(WHERE_GREATER_THAN); } else { sb.append(WHERE_LESSER_THAN); } } } sb.append(ORDER_BY_CLAUSE); String[] orderByFields = orderByComparator.getOrderByFields(); for (int i = 0; i < orderByFields.length; i++) { sb.append(_ORDER_BY_ENTITY_ALIAS); sb.append(orderByFields[i]); if ((i + 1) < orderByFields.length) { if (orderByComparator.isAscending() ^ previous) { sb.append(ORDER_BY_ASC_HAS_NEXT); } else { sb.append(ORDER_BY_DESC_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { sb.append(ORDER_BY_ASC); } else { sb.append(ORDER_BY_DESC); } } } } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Query query = session.createQuery(sql); query.setFirstResult(0); query.setMaxResults(2); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(segmentsExperienceId); queryPos.add(plid); queryPos.add(deleted); if (orderByComparator != null) { for (Object orderByConditionValue : orderByComparator.getOrderByConditionValues( fragmentEntryLink)) { queryPos.add(orderByConditionValue); } } List list = query.list(); if (list.size() == 2) { return list.get(1); } else { return null; } } /** * Returns all the fragment entry links where groupId = ? and segmentsExperienceId = any ? and plid = ? and deleted = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param segmentsExperienceIds the segments experience IDs * @param plid the plid * @param deleted the deleted * @return the matching fragment entry links */ @Override public List findByG_S_P_D( long groupId, long[] segmentsExperienceIds, long plid, boolean deleted) { return findByG_S_P_D( groupId, segmentsExperienceIds, plid, deleted, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null); } /** * Returns a range of all the fragment entry links where groupId = ? and segmentsExperienceId = any ? and plid = ? and deleted = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param segmentsExperienceIds the segments experience IDs * @param plid the plid * @param deleted the deleted * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @return the range of matching fragment entry links */ @Override public List findByG_S_P_D( long groupId, long[] segmentsExperienceIds, long plid, boolean deleted, int start, int end) { return findByG_S_P_D( groupId, segmentsExperienceIds, plid, deleted, start, end, null); } /** * Returns an ordered range of all the fragment entry links where groupId = ? and segmentsExperienceId = any ? and plid = ? and deleted = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param segmentsExperienceIds the segments experience IDs * @param plid the plid * @param deleted the deleted * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @return the ordered range of matching fragment entry links */ @Override public List findByG_S_P_D( long groupId, long[] segmentsExperienceIds, long plid, boolean deleted, int start, int end, OrderByComparator orderByComparator) { return findByG_S_P_D( groupId, segmentsExperienceIds, plid, deleted, start, end, orderByComparator, true); } /** * Returns an ordered range of all the fragment entry links where groupId = ? and segmentsExperienceId = ? and plid = ? and deleted = ?, optionally using the finder cache. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param segmentsExperienceIds the segments experience IDs * @param plid the plid * @param deleted the deleted * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @param useFinderCache whether to use the finder cache * @return the ordered range of matching fragment entry links */ @Override public List findByG_S_P_D( long groupId, long[] segmentsExperienceIds, long plid, boolean deleted, int start, int end, OrderByComparator orderByComparator, boolean useFinderCache) { if (segmentsExperienceIds == null) { segmentsExperienceIds = new long[0]; } else if (segmentsExperienceIds.length > 1) { segmentsExperienceIds = ArrayUtil.sortedUnique( segmentsExperienceIds); } if (segmentsExperienceIds.length == 1) { return findByG_S_P_D( groupId, segmentsExperienceIds[0], plid, deleted, start, end, orderByComparator); } try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { Object[] finderArgs = null; if ((start == QueryUtil.ALL_POS) && (end == QueryUtil.ALL_POS) && (orderByComparator == null)) { if (useFinderCache) { finderArgs = new Object[] { groupId, StringUtil.merge(segmentsExperienceIds), plid, deleted }; } } else if (useFinderCache) { finderArgs = new Object[] { groupId, StringUtil.merge(segmentsExperienceIds), plid, deleted, start, end, orderByComparator }; } List list = null; if (useFinderCache) { list = (List)finderCache.getResult( _finderPathWithPaginationFindByG_S_P_D, finderArgs, this); if ((list != null) && !list.isEmpty()) { for (FragmentEntryLink fragmentEntryLink : list) { if ((groupId != fragmentEntryLink.getGroupId()) || !ArrayUtil.contains( segmentsExperienceIds, fragmentEntryLink.getSegmentsExperienceId()) || (plid != fragmentEntryLink.getPlid()) || (deleted != fragmentEntryLink.isDeleted())) { list = null; break; } } } } if (list == null) { StringBundler sb = new StringBundler(); sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_S_P_D_GROUPID_2); if (segmentsExperienceIds.length > 0) { sb.append("("); sb.append(_FINDER_COLUMN_G_S_P_D_SEGMENTSEXPERIENCEID_7); sb.append(StringUtil.merge(segmentsExperienceIds)); sb.append(")"); sb.append(")"); sb.append(WHERE_AND); } sb.append(_FINDER_COLUMN_G_S_P_D_PLID_2); sb.append(_FINDER_COLUMN_G_S_P_D_DELETED_2); sb.setStringAt( removeConjunction(sb.stringAt(sb.index() - 1)), sb.index() - 1); if (orderByComparator != null) { appendOrderByComparator( sb, _ORDER_BY_ENTITY_ALIAS, orderByComparator); } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(plid); queryPos.add(deleted); list = (List)QueryUtil.list( query, getDialect(), start, end); cacheResult(list); if (useFinderCache) { finderCache.putResult( _finderPathWithPaginationFindByG_S_P_D, finderArgs, list); } } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return list; } } /** * Removes all the fragment entry links where groupId = ? and segmentsExperienceId = ? and plid = ? and deleted = ? from the database. * * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param plid the plid * @param deleted the deleted */ @Override public void removeByG_S_P_D( long groupId, long segmentsExperienceId, long plid, boolean deleted) { for (FragmentEntryLink fragmentEntryLink : findByG_S_P_D( groupId, segmentsExperienceId, plid, deleted, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null)) { remove(fragmentEntryLink); } } /** * Returns the number of fragment entry links where groupId = ? and segmentsExperienceId = ? and plid = ? and deleted = ?. * * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param plid the plid * @param deleted the deleted * @return the number of matching fragment entry links */ @Override public int countByG_S_P_D( long groupId, long segmentsExperienceId, long plid, boolean deleted) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { FinderPath finderPath = _finderPathCountByG_S_P_D; Object[] finderArgs = new Object[] { groupId, segmentsExperienceId, plid, deleted }; Long count = (Long)finderCache.getResult( finderPath, finderArgs, this); if (count == null) { StringBundler sb = new StringBundler(5); sb.append(_SQL_COUNT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_S_P_D_GROUPID_2); sb.append(_FINDER_COLUMN_G_S_P_D_SEGMENTSEXPERIENCEID_2); sb.append(_FINDER_COLUMN_G_S_P_D_PLID_2); sb.append(_FINDER_COLUMN_G_S_P_D_DELETED_2); String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(segmentsExperienceId); queryPos.add(plid); queryPos.add(deleted); count = (Long)query.uniqueResult(); finderCache.putResult(finderPath, finderArgs, count); } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return count.intValue(); } } /** * Returns the number of fragment entry links where groupId = ? and segmentsExperienceId = any ? and plid = ? and deleted = ?. * * @param groupId the group ID * @param segmentsExperienceIds the segments experience IDs * @param plid the plid * @param deleted the deleted * @return the number of matching fragment entry links */ @Override public int countByG_S_P_D( long groupId, long[] segmentsExperienceIds, long plid, boolean deleted) { if (segmentsExperienceIds == null) { segmentsExperienceIds = new long[0]; } else if (segmentsExperienceIds.length > 1) { segmentsExperienceIds = ArrayUtil.sortedUnique( segmentsExperienceIds); } try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { Object[] finderArgs = new Object[] { groupId, StringUtil.merge(segmentsExperienceIds), plid, deleted }; Long count = (Long)finderCache.getResult( _finderPathWithPaginationCountByG_S_P_D, finderArgs, this); if (count == null) { StringBundler sb = new StringBundler(); sb.append(_SQL_COUNT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_S_P_D_GROUPID_2); if (segmentsExperienceIds.length > 0) { sb.append("("); sb.append(_FINDER_COLUMN_G_S_P_D_SEGMENTSEXPERIENCEID_7); sb.append(StringUtil.merge(segmentsExperienceIds)); sb.append(")"); sb.append(")"); sb.append(WHERE_AND); } sb.append(_FINDER_COLUMN_G_S_P_D_PLID_2); sb.append(_FINDER_COLUMN_G_S_P_D_DELETED_2); sb.setStringAt( removeConjunction(sb.stringAt(sb.index() - 1)), sb.index() - 1); String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(plid); queryPos.add(deleted); count = (Long)query.uniqueResult(); finderCache.putResult( _finderPathWithPaginationCountByG_S_P_D, finderArgs, count); } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return count.intValue(); } } private static final String _FINDER_COLUMN_G_S_P_D_GROUPID_2 = "fragmentEntryLink.groupId = ? AND "; private static final String _FINDER_COLUMN_G_S_P_D_SEGMENTSEXPERIENCEID_2 = "fragmentEntryLink.segmentsExperienceId = ? AND "; private static final String _FINDER_COLUMN_G_S_P_D_SEGMENTSEXPERIENCEID_7 = "fragmentEntryLink.segmentsExperienceId IN ("; private static final String _FINDER_COLUMN_G_S_P_D_PLID_2 = "fragmentEntryLink.plid = ? AND "; private static final String _FINDER_COLUMN_G_S_P_D_DELETED_2 = "fragmentEntryLink.deleted = ?"; private FinderPath _finderPathWithPaginationFindByG_S_P_R; private FinderPath _finderPathWithoutPaginationFindByG_S_P_R; private FinderPath _finderPathCountByG_S_P_R; /** * Returns all the fragment entry links where groupId = ? and segmentsExperienceId = ? and plid = ? and rendererKey = ?. * * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param plid the plid * @param rendererKey the renderer key * @return the matching fragment entry links */ @Override public List findByG_S_P_R( long groupId, long segmentsExperienceId, long plid, String rendererKey) { return findByG_S_P_R( groupId, segmentsExperienceId, plid, rendererKey, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null); } /** * Returns a range of all the fragment entry links where groupId = ? and segmentsExperienceId = ? and plid = ? and rendererKey = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param plid the plid * @param rendererKey the renderer key * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @return the range of matching fragment entry links */ @Override public List findByG_S_P_R( long groupId, long segmentsExperienceId, long plid, String rendererKey, int start, int end) { return findByG_S_P_R( groupId, segmentsExperienceId, plid, rendererKey, start, end, null); } /** * Returns an ordered range of all the fragment entry links where groupId = ? and segmentsExperienceId = ? and plid = ? and rendererKey = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param plid the plid * @param rendererKey the renderer key * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @return the ordered range of matching fragment entry links */ @Override public List findByG_S_P_R( long groupId, long segmentsExperienceId, long plid, String rendererKey, int start, int end, OrderByComparator orderByComparator) { return findByG_S_P_R( groupId, segmentsExperienceId, plid, rendererKey, start, end, orderByComparator, true); } /** * Returns an ordered range of all the fragment entry links where groupId = ? and segmentsExperienceId = ? and plid = ? and rendererKey = ?. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param plid the plid * @param rendererKey the renderer key * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @param useFinderCache whether to use the finder cache * @return the ordered range of matching fragment entry links */ @Override public List findByG_S_P_R( long groupId, long segmentsExperienceId, long plid, String rendererKey, int start, int end, OrderByComparator orderByComparator, boolean useFinderCache) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { rendererKey = Objects.toString(rendererKey, ""); FinderPath finderPath = null; Object[] finderArgs = null; if ((start == QueryUtil.ALL_POS) && (end == QueryUtil.ALL_POS) && (orderByComparator == null)) { if (useFinderCache) { finderPath = _finderPathWithoutPaginationFindByG_S_P_R; finderArgs = new Object[] { groupId, segmentsExperienceId, plid, rendererKey }; } } else if (useFinderCache) { finderPath = _finderPathWithPaginationFindByG_S_P_R; finderArgs = new Object[] { groupId, segmentsExperienceId, plid, rendererKey, start, end, orderByComparator }; } List list = null; if (useFinderCache) { list = (List)finderCache.getResult( finderPath, finderArgs, this); if ((list != null) && !list.isEmpty()) { for (FragmentEntryLink fragmentEntryLink : list) { if ((groupId != fragmentEntryLink.getGroupId()) || (segmentsExperienceId != fragmentEntryLink.getSegmentsExperienceId()) || (plid != fragmentEntryLink.getPlid()) || !rendererKey.equals( fragmentEntryLink.getRendererKey())) { list = null; break; } } } } if (list == null) { StringBundler sb = null; if (orderByComparator != null) { sb = new StringBundler( 6 + (orderByComparator.getOrderByFields().length * 2)); } else { sb = new StringBundler(6); } sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_S_P_R_GROUPID_2); sb.append(_FINDER_COLUMN_G_S_P_R_SEGMENTSEXPERIENCEID_2); sb.append(_FINDER_COLUMN_G_S_P_R_PLID_2); boolean bindRendererKey = false; if (rendererKey.isEmpty()) { sb.append(_FINDER_COLUMN_G_S_P_R_RENDERERKEY_3); } else { bindRendererKey = true; sb.append(_FINDER_COLUMN_G_S_P_R_RENDERERKEY_2); } if (orderByComparator != null) { appendOrderByComparator( sb, _ORDER_BY_ENTITY_ALIAS, orderByComparator); } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(segmentsExperienceId); queryPos.add(plid); if (bindRendererKey) { queryPos.add(rendererKey); } list = (List)QueryUtil.list( query, getDialect(), start, end); cacheResult(list); if (useFinderCache) { finderCache.putResult(finderPath, finderArgs, list); } } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return list; } } /** * Returns the first fragment entry link in the ordered set where groupId = ? and segmentsExperienceId = ? and plid = ? and rendererKey = ?. * * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param plid the plid * @param rendererKey the renderer key * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByG_S_P_R_First( long groupId, long segmentsExperienceId, long plid, String rendererKey, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByG_S_P_R_First( groupId, segmentsExperienceId, plid, rendererKey, orderByComparator); if (fragmentEntryLink != null) { return fragmentEntryLink; } StringBundler sb = new StringBundler(10); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("groupId="); sb.append(groupId); sb.append(", segmentsExperienceId="); sb.append(segmentsExperienceId); sb.append(", plid="); sb.append(plid); sb.append(", rendererKey="); sb.append(rendererKey); sb.append("}"); throw new NoSuchEntryLinkException(sb.toString()); } /** * Returns the first fragment entry link in the ordered set where groupId = ? and segmentsExperienceId = ? and plid = ? and rendererKey = ?. * * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param plid the plid * @param rendererKey the renderer key * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByG_S_P_R_First( long groupId, long segmentsExperienceId, long plid, String rendererKey, OrderByComparator orderByComparator) { List list = findByG_S_P_R( groupId, segmentsExperienceId, plid, rendererKey, 0, 1, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the last fragment entry link in the ordered set where groupId = ? and segmentsExperienceId = ? and plid = ? and rendererKey = ?. * * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param plid the plid * @param rendererKey the renderer key * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByG_S_P_R_Last( long groupId, long segmentsExperienceId, long plid, String rendererKey, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByG_S_P_R_Last( groupId, segmentsExperienceId, plid, rendererKey, orderByComparator); if (fragmentEntryLink != null) { return fragmentEntryLink; } StringBundler sb = new StringBundler(10); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("groupId="); sb.append(groupId); sb.append(", segmentsExperienceId="); sb.append(segmentsExperienceId); sb.append(", plid="); sb.append(plid); sb.append(", rendererKey="); sb.append(rendererKey); sb.append("}"); throw new NoSuchEntryLinkException(sb.toString()); } /** * Returns the last fragment entry link in the ordered set where groupId = ? and segmentsExperienceId = ? and plid = ? and rendererKey = ?. * * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param plid the plid * @param rendererKey the renderer key * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByG_S_P_R_Last( long groupId, long segmentsExperienceId, long plid, String rendererKey, OrderByComparator orderByComparator) { int count = countByG_S_P_R( groupId, segmentsExperienceId, plid, rendererKey); if (count == 0) { return null; } List list = findByG_S_P_R( groupId, segmentsExperienceId, plid, rendererKey, count - 1, count, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the fragment entry links before and after the current fragment entry link in the ordered set where groupId = ? and segmentsExperienceId = ? and plid = ? and rendererKey = ?. * * @param fragmentEntryLinkId the primary key of the current fragment entry link * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param plid the plid * @param rendererKey the renderer key * @param orderByComparator the comparator to order the set by (optionally null) * @return the previous, current, and next fragment entry link * @throws NoSuchEntryLinkException if a fragment entry link with the primary key could not be found */ @Override public FragmentEntryLink[] findByG_S_P_R_PrevAndNext( long fragmentEntryLinkId, long groupId, long segmentsExperienceId, long plid, String rendererKey, OrderByComparator orderByComparator) throws NoSuchEntryLinkException { rendererKey = Objects.toString(rendererKey, ""); FragmentEntryLink fragmentEntryLink = findByPrimaryKey( fragmentEntryLinkId); Session session = null; try { session = openSession(); FragmentEntryLink[] array = new FragmentEntryLinkImpl[3]; array[0] = getByG_S_P_R_PrevAndNext( session, fragmentEntryLink, groupId, segmentsExperienceId, plid, rendererKey, orderByComparator, true); array[1] = fragmentEntryLink; array[2] = getByG_S_P_R_PrevAndNext( session, fragmentEntryLink, groupId, segmentsExperienceId, plid, rendererKey, orderByComparator, false); return array; } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } protected FragmentEntryLink getByG_S_P_R_PrevAndNext( Session session, FragmentEntryLink fragmentEntryLink, long groupId, long segmentsExperienceId, long plid, String rendererKey, OrderByComparator orderByComparator, boolean previous) { StringBundler sb = null; if (orderByComparator != null) { sb = new StringBundler( 7 + (orderByComparator.getOrderByConditionFields().length * 3) + (orderByComparator.getOrderByFields().length * 3)); } else { sb = new StringBundler(6); } sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_S_P_R_GROUPID_2); sb.append(_FINDER_COLUMN_G_S_P_R_SEGMENTSEXPERIENCEID_2); sb.append(_FINDER_COLUMN_G_S_P_R_PLID_2); boolean bindRendererKey = false; if (rendererKey.isEmpty()) { sb.append(_FINDER_COLUMN_G_S_P_R_RENDERERKEY_3); } else { bindRendererKey = true; sb.append(_FINDER_COLUMN_G_S_P_R_RENDERERKEY_2); } if (orderByComparator != null) { String[] orderByConditionFields = orderByComparator.getOrderByConditionFields(); if (orderByConditionFields.length > 0) { sb.append(WHERE_AND); } for (int i = 0; i < orderByConditionFields.length; i++) { sb.append(_ORDER_BY_ENTITY_ALIAS); sb.append(orderByConditionFields[i]); if ((i + 1) < orderByConditionFields.length) { if (orderByComparator.isAscending() ^ previous) { sb.append(WHERE_GREATER_THAN_HAS_NEXT); } else { sb.append(WHERE_LESSER_THAN_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { sb.append(WHERE_GREATER_THAN); } else { sb.append(WHERE_LESSER_THAN); } } } sb.append(ORDER_BY_CLAUSE); String[] orderByFields = orderByComparator.getOrderByFields(); for (int i = 0; i < orderByFields.length; i++) { sb.append(_ORDER_BY_ENTITY_ALIAS); sb.append(orderByFields[i]); if ((i + 1) < orderByFields.length) { if (orderByComparator.isAscending() ^ previous) { sb.append(ORDER_BY_ASC_HAS_NEXT); } else { sb.append(ORDER_BY_DESC_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { sb.append(ORDER_BY_ASC); } else { sb.append(ORDER_BY_DESC); } } } } else { sb.append(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } String sql = sb.toString(); Query query = session.createQuery(sql); query.setFirstResult(0); query.setMaxResults(2); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(segmentsExperienceId); queryPos.add(plid); if (bindRendererKey) { queryPos.add(rendererKey); } if (orderByComparator != null) { for (Object orderByConditionValue : orderByComparator.getOrderByConditionValues( fragmentEntryLink)) { queryPos.add(orderByConditionValue); } } List list = query.list(); if (list.size() == 2) { return list.get(1); } else { return null; } } /** * Removes all the fragment entry links where groupId = ? and segmentsExperienceId = ? and plid = ? and rendererKey = ? from the database. * * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param plid the plid * @param rendererKey the renderer key */ @Override public void removeByG_S_P_R( long groupId, long segmentsExperienceId, long plid, String rendererKey) { for (FragmentEntryLink fragmentEntryLink : findByG_S_P_R( groupId, segmentsExperienceId, plid, rendererKey, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null)) { remove(fragmentEntryLink); } } /** * Returns the number of fragment entry links where groupId = ? and segmentsExperienceId = ? and plid = ? and rendererKey = ?. * * @param groupId the group ID * @param segmentsExperienceId the segments experience ID * @param plid the plid * @param rendererKey the renderer key * @return the number of matching fragment entry links */ @Override public int countByG_S_P_R( long groupId, long segmentsExperienceId, long plid, String rendererKey) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { rendererKey = Objects.toString(rendererKey, ""); FinderPath finderPath = _finderPathCountByG_S_P_R; Object[] finderArgs = new Object[] { groupId, segmentsExperienceId, plid, rendererKey }; Long count = (Long)finderCache.getResult( finderPath, finderArgs, this); if (count == null) { StringBundler sb = new StringBundler(5); sb.append(_SQL_COUNT_FRAGMENTENTRYLINK_WHERE); sb.append(_FINDER_COLUMN_G_S_P_R_GROUPID_2); sb.append(_FINDER_COLUMN_G_S_P_R_SEGMENTSEXPERIENCEID_2); sb.append(_FINDER_COLUMN_G_S_P_R_PLID_2); boolean bindRendererKey = false; if (rendererKey.isEmpty()) { sb.append(_FINDER_COLUMN_G_S_P_R_RENDERERKEY_3); } else { bindRendererKey = true; sb.append(_FINDER_COLUMN_G_S_P_R_RENDERERKEY_2); } String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(groupId); queryPos.add(segmentsExperienceId); queryPos.add(plid); if (bindRendererKey) { queryPos.add(rendererKey); } count = (Long)query.uniqueResult(); finderCache.putResult(finderPath, finderArgs, count); } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return count.intValue(); } } private static final String _FINDER_COLUMN_G_S_P_R_GROUPID_2 = "fragmentEntryLink.groupId = ? AND "; private static final String _FINDER_COLUMN_G_S_P_R_SEGMENTSEXPERIENCEID_2 = "fragmentEntryLink.segmentsExperienceId = ? AND "; private static final String _FINDER_COLUMN_G_S_P_R_PLID_2 = "fragmentEntryLink.plid = ? AND "; private static final String _FINDER_COLUMN_G_S_P_R_RENDERERKEY_2 = "fragmentEntryLink.rendererKey = ?"; private static final String _FINDER_COLUMN_G_S_P_R_RENDERERKEY_3 = "(fragmentEntryLink.rendererKey IS NULL OR fragmentEntryLink.rendererKey = '')"; private FinderPath _finderPathFetchByERC_G; private FinderPath _finderPathCountByERC_G; /** * Returns the fragment entry link where externalReferenceCode = ? and groupId = ? or throws a NoSuchEntryLinkException if it could not be found. * * @param externalReferenceCode the external reference code * @param groupId the group ID * @return the matching fragment entry link * @throws NoSuchEntryLinkException if a matching fragment entry link could not be found */ @Override public FragmentEntryLink findByERC_G( String externalReferenceCode, long groupId) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByERC_G( externalReferenceCode, groupId); if (fragmentEntryLink == null) { StringBundler sb = new StringBundler(6); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("externalReferenceCode="); sb.append(externalReferenceCode); sb.append(", groupId="); sb.append(groupId); sb.append("}"); if (_log.isDebugEnabled()) { _log.debug(sb.toString()); } throw new NoSuchEntryLinkException(sb.toString()); } return fragmentEntryLink; } /** * Returns the fragment entry link where externalReferenceCode = ? and groupId = ? or returns null if it could not be found. Uses the finder cache. * * @param externalReferenceCode the external reference code * @param groupId the group ID * @return the matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByERC_G( String externalReferenceCode, long groupId) { return fetchByERC_G(externalReferenceCode, groupId, true); } /** * Returns the fragment entry link where externalReferenceCode = ? and groupId = ? or returns null if it could not be found, optionally using the finder cache. * * @param externalReferenceCode the external reference code * @param groupId the group ID * @param useFinderCache whether to use the finder cache * @return the matching fragment entry link, or null if a matching fragment entry link could not be found */ @Override public FragmentEntryLink fetchByERC_G( String externalReferenceCode, long groupId, boolean useFinderCache) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { externalReferenceCode = Objects.toString(externalReferenceCode, ""); Object[] finderArgs = null; if (useFinderCache) { finderArgs = new Object[] {externalReferenceCode, groupId}; } Object result = null; if (useFinderCache) { result = finderCache.getResult( _finderPathFetchByERC_G, finderArgs, this); } if (result instanceof FragmentEntryLink) { FragmentEntryLink fragmentEntryLink = (FragmentEntryLink)result; if (!Objects.equals( externalReferenceCode, fragmentEntryLink.getExternalReferenceCode()) || (groupId != fragmentEntryLink.getGroupId())) { result = null; } } if (result == null) { StringBundler sb = new StringBundler(4); sb.append(_SQL_SELECT_FRAGMENTENTRYLINK_WHERE); boolean bindExternalReferenceCode = false; if (externalReferenceCode.isEmpty()) { sb.append(_FINDER_COLUMN_ERC_G_EXTERNALREFERENCECODE_3); } else { bindExternalReferenceCode = true; sb.append(_FINDER_COLUMN_ERC_G_EXTERNALREFERENCECODE_2); } sb.append(_FINDER_COLUMN_ERC_G_GROUPID_2); String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); if (bindExternalReferenceCode) { queryPos.add(externalReferenceCode); } queryPos.add(groupId); List list = query.list(); if (list.isEmpty()) { if (useFinderCache) { finderCache.putResult( _finderPathFetchByERC_G, finderArgs, list); } } else { FragmentEntryLink fragmentEntryLink = list.get(0); result = fragmentEntryLink; cacheResult(fragmentEntryLink); } } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } if (result instanceof List) { return null; } else { return (FragmentEntryLink)result; } } } /** * Removes the fragment entry link where externalReferenceCode = ? and groupId = ? from the database. * * @param externalReferenceCode the external reference code * @param groupId the group ID * @return the fragment entry link that was removed */ @Override public FragmentEntryLink removeByERC_G( String externalReferenceCode, long groupId) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = findByERC_G( externalReferenceCode, groupId); return remove(fragmentEntryLink); } /** * Returns the number of fragment entry links where externalReferenceCode = ? and groupId = ?. * * @param externalReferenceCode the external reference code * @param groupId the group ID * @return the number of matching fragment entry links */ @Override public int countByERC_G(String externalReferenceCode, long groupId) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { externalReferenceCode = Objects.toString(externalReferenceCode, ""); FinderPath finderPath = _finderPathCountByERC_G; Object[] finderArgs = new Object[] {externalReferenceCode, groupId}; Long count = (Long)finderCache.getResult( finderPath, finderArgs, this); if (count == null) { StringBundler sb = new StringBundler(3); sb.append(_SQL_COUNT_FRAGMENTENTRYLINK_WHERE); boolean bindExternalReferenceCode = false; if (externalReferenceCode.isEmpty()) { sb.append(_FINDER_COLUMN_ERC_G_EXTERNALREFERENCECODE_3); } else { bindExternalReferenceCode = true; sb.append(_FINDER_COLUMN_ERC_G_EXTERNALREFERENCECODE_2); } sb.append(_FINDER_COLUMN_ERC_G_GROUPID_2); String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); if (bindExternalReferenceCode) { queryPos.add(externalReferenceCode); } queryPos.add(groupId); count = (Long)query.uniqueResult(); finderCache.putResult(finderPath, finderArgs, count); } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return count.intValue(); } } private static final String _FINDER_COLUMN_ERC_G_EXTERNALREFERENCECODE_2 = "fragmentEntryLink.externalReferenceCode = ? AND "; private static final String _FINDER_COLUMN_ERC_G_EXTERNALREFERENCECODE_3 = "(fragmentEntryLink.externalReferenceCode IS NULL OR fragmentEntryLink.externalReferenceCode = '') AND "; private static final String _FINDER_COLUMN_ERC_G_GROUPID_2 = "fragmentEntryLink.groupId = ?"; public FragmentEntryLinkPersistenceImpl() { Map dbColumnNames = new HashMap(); dbColumnNames.put("uuid", "uuid_"); dbColumnNames.put("type", "type_"); setDBColumnNames(dbColumnNames); setModelClass(FragmentEntryLink.class); setModelImplClass(FragmentEntryLinkImpl.class); setModelPKClass(long.class); setTable(FragmentEntryLinkTable.INSTANCE); } /** * Caches the fragment entry link in the entity cache if it is enabled. * * @param fragmentEntryLink the fragment entry link */ @Override public void cacheResult(FragmentEntryLink fragmentEntryLink) { try (SafeCloseable safeCloseable = CTCollectionThreadLocal.setCTCollectionIdWithSafeCloseable( fragmentEntryLink.getCtCollectionId())) { entityCache.putResult( FragmentEntryLinkImpl.class, fragmentEntryLink.getPrimaryKey(), fragmentEntryLink); finderCache.putResult( _finderPathFetchByUUID_G, new Object[] { fragmentEntryLink.getUuid(), fragmentEntryLink.getGroupId() }, fragmentEntryLink); finderCache.putResult( _finderPathFetchByERC_G, new Object[] { fragmentEntryLink.getExternalReferenceCode(), fragmentEntryLink.getGroupId() }, fragmentEntryLink); } } private int _valueObjectFinderCacheListThreshold; /** * Caches the fragment entry links in the entity cache if it is enabled. * * @param fragmentEntryLinks the fragment entry links */ @Override public void cacheResult(List fragmentEntryLinks) { if ((_valueObjectFinderCacheListThreshold == 0) || ((_valueObjectFinderCacheListThreshold > 0) && (fragmentEntryLinks.size() > _valueObjectFinderCacheListThreshold))) { return; } for (FragmentEntryLink fragmentEntryLink : fragmentEntryLinks) { try (SafeCloseable safeCloseable = CTCollectionThreadLocal.setCTCollectionIdWithSafeCloseable( fragmentEntryLink.getCtCollectionId())) { if (entityCache.getResult( FragmentEntryLinkImpl.class, fragmentEntryLink.getPrimaryKey()) == null) { cacheResult(fragmentEntryLink); } } } } /** * Clears the cache for all fragment entry links. * *

* The EntityCache and FinderCache are both cleared by this method. *

*/ @Override public void clearCache() { entityCache.clearCache(FragmentEntryLinkImpl.class); finderCache.clearCache(FragmentEntryLinkImpl.class); } /** * Clears the cache for the fragment entry link. * *

* The EntityCache and FinderCache are both cleared by this method. *

*/ @Override public void clearCache(FragmentEntryLink fragmentEntryLink) { entityCache.removeResult( FragmentEntryLinkImpl.class, fragmentEntryLink); } @Override public void clearCache(List fragmentEntryLinks) { for (FragmentEntryLink fragmentEntryLink : fragmentEntryLinks) { entityCache.removeResult( FragmentEntryLinkImpl.class, fragmentEntryLink); } } @Override public void clearCache(Set primaryKeys) { finderCache.clearCache(FragmentEntryLinkImpl.class); for (Serializable primaryKey : primaryKeys) { entityCache.removeResult(FragmentEntryLinkImpl.class, primaryKey); } } protected void cacheUniqueFindersCache( FragmentEntryLinkModelImpl fragmentEntryLinkModelImpl) { try (SafeCloseable safeCloseable = CTCollectionThreadLocal.setCTCollectionIdWithSafeCloseable( fragmentEntryLinkModelImpl.getCtCollectionId())) { Object[] args = new Object[] { fragmentEntryLinkModelImpl.getUuid(), fragmentEntryLinkModelImpl.getGroupId() }; finderCache.putResult( _finderPathCountByUUID_G, args, Long.valueOf(1)); finderCache.putResult( _finderPathFetchByUUID_G, args, fragmentEntryLinkModelImpl); args = new Object[] { fragmentEntryLinkModelImpl.getExternalReferenceCode(), fragmentEntryLinkModelImpl.getGroupId() }; finderCache.putResult( _finderPathCountByERC_G, args, Long.valueOf(1)); finderCache.putResult( _finderPathFetchByERC_G, args, fragmentEntryLinkModelImpl); } } /** * Creates a new fragment entry link with the primary key. Does not add the fragment entry link to the database. * * @param fragmentEntryLinkId the primary key for the new fragment entry link * @return the new fragment entry link */ @Override public FragmentEntryLink create(long fragmentEntryLinkId) { FragmentEntryLink fragmentEntryLink = new FragmentEntryLinkImpl(); fragmentEntryLink.setNew(true); fragmentEntryLink.setPrimaryKey(fragmentEntryLinkId); String uuid = PortalUUIDUtil.generate(); fragmentEntryLink.setUuid(uuid); fragmentEntryLink.setCompanyId(CompanyThreadLocal.getCompanyId()); return fragmentEntryLink; } /** * Removes the fragment entry link with the primary key from the database. Also notifies the appropriate model listeners. * * @param fragmentEntryLinkId the primary key of the fragment entry link * @return the fragment entry link that was removed * @throws NoSuchEntryLinkException if a fragment entry link with the primary key could not be found */ @Override public FragmentEntryLink remove(long fragmentEntryLinkId) throws NoSuchEntryLinkException { return remove((Serializable)fragmentEntryLinkId); } /** * Removes the fragment entry link with the primary key from the database. Also notifies the appropriate model listeners. * * @param primaryKey the primary key of the fragment entry link * @return the fragment entry link that was removed * @throws NoSuchEntryLinkException if a fragment entry link with the primary key could not be found */ @Override public FragmentEntryLink remove(Serializable primaryKey) throws NoSuchEntryLinkException { Session session = null; try { session = openSession(); FragmentEntryLink fragmentEntryLink = (FragmentEntryLink)session.get( FragmentEntryLinkImpl.class, primaryKey); if (fragmentEntryLink == null) { if (_log.isDebugEnabled()) { _log.debug(_NO_SUCH_ENTITY_WITH_PRIMARY_KEY + primaryKey); } throw new NoSuchEntryLinkException( _NO_SUCH_ENTITY_WITH_PRIMARY_KEY + primaryKey); } return remove(fragmentEntryLink); } catch (NoSuchEntryLinkException noSuchEntityException) { throw noSuchEntityException; } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } @Override protected FragmentEntryLink removeImpl( FragmentEntryLink fragmentEntryLink) { Session session = null; try { session = openSession(); if (!session.contains(fragmentEntryLink)) { fragmentEntryLink = (FragmentEntryLink)session.get( FragmentEntryLinkImpl.class, fragmentEntryLink.getPrimaryKeyObj()); } if ((fragmentEntryLink != null) && ctPersistenceHelper.isRemove(fragmentEntryLink)) { session.delete(fragmentEntryLink); } } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } if (fragmentEntryLink != null) { clearCache(fragmentEntryLink); } return fragmentEntryLink; } @Override public FragmentEntryLink updateImpl(FragmentEntryLink fragmentEntryLink) { boolean isNew = fragmentEntryLink.isNew(); if (!(fragmentEntryLink instanceof FragmentEntryLinkModelImpl)) { InvocationHandler invocationHandler = null; if (ProxyUtil.isProxyClass(fragmentEntryLink.getClass())) { invocationHandler = ProxyUtil.getInvocationHandler( fragmentEntryLink); throw new IllegalArgumentException( "Implement ModelWrapper in fragmentEntryLink proxy " + invocationHandler.getClass()); } throw new IllegalArgumentException( "Implement ModelWrapper in custom FragmentEntryLink implementation " + fragmentEntryLink.getClass()); } FragmentEntryLinkModelImpl fragmentEntryLinkModelImpl = (FragmentEntryLinkModelImpl)fragmentEntryLink; if (Validator.isNull(fragmentEntryLink.getUuid())) { String uuid = PortalUUIDUtil.generate(); fragmentEntryLink.setUuid(uuid); } if (Validator.isNull(fragmentEntryLink.getExternalReferenceCode())) { fragmentEntryLink.setExternalReferenceCode( fragmentEntryLink.getUuid()); } else { if (!Objects.equals( fragmentEntryLinkModelImpl.getColumnOriginalValue( "externalReferenceCode"), fragmentEntryLink.getExternalReferenceCode())) { long userId = GetterUtil.getLong( PrincipalThreadLocal.getName()); if (userId > 0) { long companyId = fragmentEntryLink.getCompanyId(); long groupId = fragmentEntryLink.getGroupId(); long classPK = 0; if (!isNew) { classPK = fragmentEntryLink.getPrimaryKey(); } try { fragmentEntryLink.setExternalReferenceCode( SanitizerUtil.sanitize( companyId, groupId, userId, FragmentEntryLink.class.getName(), classPK, ContentTypes.TEXT_HTML, Sanitizer.MODE_ALL, fragmentEntryLink.getExternalReferenceCode(), null)); } catch (SanitizerException sanitizerException) { throw new SystemException(sanitizerException); } } } FragmentEntryLink ercFragmentEntryLink = fetchByERC_G( fragmentEntryLink.getExternalReferenceCode(), fragmentEntryLink.getGroupId()); if (isNew) { if (ercFragmentEntryLink != null) { throw new DuplicateFragmentEntryLinkExternalReferenceCodeException( "Duplicate fragment entry link with external reference code " + fragmentEntryLink.getExternalReferenceCode() + " and group " + fragmentEntryLink.getGroupId()); } } else { if ((ercFragmentEntryLink != null) && (fragmentEntryLink.getFragmentEntryLinkId() != ercFragmentEntryLink.getFragmentEntryLinkId())) { throw new DuplicateFragmentEntryLinkExternalReferenceCodeException( "Duplicate fragment entry link with external reference code " + fragmentEntryLink.getExternalReferenceCode() + " and group " + fragmentEntryLink.getGroupId()); } } } ServiceContext serviceContext = ServiceContextThreadLocal.getServiceContext(); Date date = new Date(); if (isNew && (fragmentEntryLink.getCreateDate() == null)) { if (serviceContext == null) { fragmentEntryLink.setCreateDate(date); } else { fragmentEntryLink.setCreateDate( serviceContext.getCreateDate(date)); } } if (!fragmentEntryLinkModelImpl.hasSetModifiedDate()) { if (serviceContext == null) { fragmentEntryLink.setModifiedDate(date); } else { fragmentEntryLink.setModifiedDate( serviceContext.getModifiedDate(date)); } } Session session = null; try { session = openSession(); if (ctPersistenceHelper.isInsert(fragmentEntryLink)) { if (!isNew) { session.evict( FragmentEntryLinkImpl.class, fragmentEntryLink.getPrimaryKeyObj()); } session.save(fragmentEntryLink); } else { fragmentEntryLink = (FragmentEntryLink)session.merge( fragmentEntryLink); } } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } entityCache.putResult( FragmentEntryLinkImpl.class, fragmentEntryLinkModelImpl, false, true); cacheUniqueFindersCache(fragmentEntryLinkModelImpl); if (isNew) { fragmentEntryLink.setNew(false); } fragmentEntryLink.resetOriginalValues(); return fragmentEntryLink; } /** * Returns the fragment entry link with the primary key or throws a com.liferay.portal.kernel.exception.NoSuchModelException if it could not be found. * * @param primaryKey the primary key of the fragment entry link * @return the fragment entry link * @throws NoSuchEntryLinkException if a fragment entry link with the primary key could not be found */ @Override public FragmentEntryLink findByPrimaryKey(Serializable primaryKey) throws NoSuchEntryLinkException { FragmentEntryLink fragmentEntryLink = fetchByPrimaryKey(primaryKey); if (fragmentEntryLink == null) { if (_log.isDebugEnabled()) { _log.debug(_NO_SUCH_ENTITY_WITH_PRIMARY_KEY + primaryKey); } throw new NoSuchEntryLinkException( _NO_SUCH_ENTITY_WITH_PRIMARY_KEY + primaryKey); } return fragmentEntryLink; } /** * Returns the fragment entry link with the primary key or throws a NoSuchEntryLinkException if it could not be found. * * @param fragmentEntryLinkId the primary key of the fragment entry link * @return the fragment entry link * @throws NoSuchEntryLinkException if a fragment entry link with the primary key could not be found */ @Override public FragmentEntryLink findByPrimaryKey(long fragmentEntryLinkId) throws NoSuchEntryLinkException { return findByPrimaryKey((Serializable)fragmentEntryLinkId); } /** * Returns the fragment entry link with the primary key or returns null if it could not be found. * * @param primaryKey the primary key of the fragment entry link * @return the fragment entry link, or null if a fragment entry link with the primary key could not be found */ @Override public FragmentEntryLink fetchByPrimaryKey(Serializable primaryKey) { if (ctPersistenceHelper.isProductionMode( FragmentEntryLink.class, primaryKey)) { try (SafeCloseable safeCloseable = CTCollectionThreadLocal. setProductionModeWithSafeCloseable()) { return super.fetchByPrimaryKey(primaryKey); } } FragmentEntryLink fragmentEntryLink = (FragmentEntryLink)entityCache.getResult( FragmentEntryLinkImpl.class, primaryKey); if (fragmentEntryLink != null) { return fragmentEntryLink; } Session session = null; try { session = openSession(); fragmentEntryLink = (FragmentEntryLink)session.get( FragmentEntryLinkImpl.class, primaryKey); if (fragmentEntryLink != null) { cacheResult(fragmentEntryLink); } } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } return fragmentEntryLink; } /** * Returns the fragment entry link with the primary key or returns null if it could not be found. * * @param fragmentEntryLinkId the primary key of the fragment entry link * @return the fragment entry link, or null if a fragment entry link with the primary key could not be found */ @Override public FragmentEntryLink fetchByPrimaryKey(long fragmentEntryLinkId) { return fetchByPrimaryKey((Serializable)fragmentEntryLinkId); } @Override public Map fetchByPrimaryKeys( Set primaryKeys) { if (ctPersistenceHelper.isProductionMode(FragmentEntryLink.class)) { try (SafeCloseable safeCloseable = CTCollectionThreadLocal. setProductionModeWithSafeCloseable()) { return super.fetchByPrimaryKeys(primaryKeys); } } if (primaryKeys.isEmpty()) { return Collections.emptyMap(); } Map map = new HashMap(); if (primaryKeys.size() == 1) { Iterator iterator = primaryKeys.iterator(); Serializable primaryKey = iterator.next(); FragmentEntryLink fragmentEntryLink = fetchByPrimaryKey(primaryKey); if (fragmentEntryLink != null) { map.put(primaryKey, fragmentEntryLink); } return map; } Set uncachedPrimaryKeys = null; for (Serializable primaryKey : primaryKeys) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class, primaryKey)) { FragmentEntryLink fragmentEntryLink = (FragmentEntryLink)entityCache.getResult( FragmentEntryLinkImpl.class, primaryKey); if (fragmentEntryLink == null) { if (uncachedPrimaryKeys == null) { uncachedPrimaryKeys = new HashSet<>(); } uncachedPrimaryKeys.add(primaryKey); } else { map.put(primaryKey, fragmentEntryLink); } } } if (uncachedPrimaryKeys == null) { return map; } if ((databaseInMaxParameters > 0) && (primaryKeys.size() > databaseInMaxParameters)) { Iterator iterator = primaryKeys.iterator(); while (iterator.hasNext()) { Set page = new HashSet<>(); for (int i = 0; (i < databaseInMaxParameters) && iterator.hasNext(); i++) { page.add(iterator.next()); } map.putAll(fetchByPrimaryKeys(page)); } return map; } StringBundler sb = new StringBundler((primaryKeys.size() * 2) + 1); sb.append(getSelectSQL()); sb.append(" WHERE "); sb.append(getPKDBName()); sb.append(" IN ("); for (Serializable primaryKey : primaryKeys) { sb.append((long)primaryKey); sb.append(","); } sb.setIndex(sb.index() - 1); sb.append(")"); String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); for (FragmentEntryLink fragmentEntryLink : (List)query.list()) { map.put( fragmentEntryLink.getPrimaryKeyObj(), fragmentEntryLink); cacheResult(fragmentEntryLink); } } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } return map; } /** * Returns all the fragment entry links. * * @return the fragment entry links */ @Override public List findAll() { return findAll(QueryUtil.ALL_POS, QueryUtil.ALL_POS, null); } /** * Returns a range of all the fragment entry links. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @return the range of fragment entry links */ @Override public List findAll(int start, int end) { return findAll(start, end, null); } /** * Returns an ordered range of all the fragment entry links. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @return the ordered range of fragment entry links */ @Override public List findAll( int start, int end, OrderByComparator orderByComparator) { return findAll(start, end, orderByComparator, true); } /** * Returns an ordered range of all the fragment entry links. * *

* Useful when paginating results. Returns a maximum of end - start instances. start and end are not primary keys, they are indexes in the result set. Thus, 0 refers to the first result in the set. Setting both start and end to QueryUtil#ALL_POS will return the full result set. If orderByComparator is specified, then the query will include the given ORDER BY logic. If orderByComparator is absent, then the query will include the default ORDER BY logic from FragmentEntryLinkModelImpl. *

* * @param start the lower bound of the range of fragment entry links * @param end the upper bound of the range of fragment entry links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @param useFinderCache whether to use the finder cache * @return the ordered range of fragment entry links */ @Override public List findAll( int start, int end, OrderByComparator orderByComparator, boolean useFinderCache) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { FinderPath finderPath = null; Object[] finderArgs = null; if ((start == QueryUtil.ALL_POS) && (end == QueryUtil.ALL_POS) && (orderByComparator == null)) { if (useFinderCache) { finderPath = _finderPathWithoutPaginationFindAll; finderArgs = FINDER_ARGS_EMPTY; } } else if (useFinderCache) { finderPath = _finderPathWithPaginationFindAll; finderArgs = new Object[] {start, end, orderByComparator}; } List list = null; if (useFinderCache) { list = (List)finderCache.getResult( finderPath, finderArgs, this); } if (list == null) { StringBundler sb = null; String sql = null; if (orderByComparator != null) { sb = new StringBundler( 2 + (orderByComparator.getOrderByFields().length * 2)); sb.append(_SQL_SELECT_FRAGMENTENTRYLINK); appendOrderByComparator( sb, _ORDER_BY_ENTITY_ALIAS, orderByComparator); sql = sb.toString(); } else { sql = _SQL_SELECT_FRAGMENTENTRYLINK; sql = sql.concat(FragmentEntryLinkModelImpl.ORDER_BY_JPQL); } Session session = null; try { session = openSession(); Query query = session.createQuery(sql); list = (List)QueryUtil.list( query, getDialect(), start, end); cacheResult(list); if (useFinderCache) { finderCache.putResult(finderPath, finderArgs, list); } } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return list; } } /** * Removes all the fragment entry links from the database. * */ @Override public void removeAll() { for (FragmentEntryLink fragmentEntryLink : findAll()) { remove(fragmentEntryLink); } } /** * Returns the number of fragment entry links. * * @return the number of fragment entry links */ @Override public int countAll() { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( FragmentEntryLink.class)) { Long count = (Long)finderCache.getResult( _finderPathCountAll, FINDER_ARGS_EMPTY, this); if (count == null) { Session session = null; try { session = openSession(); Query query = session.createQuery( _SQL_COUNT_FRAGMENTENTRYLINK); count = (Long)query.uniqueResult(); finderCache.putResult( _finderPathCountAll, FINDER_ARGS_EMPTY, count); } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } return count.intValue(); } } @Override public Set getBadColumnNames() { return _badColumnNames; } @Override protected EntityCache getEntityCache() { return entityCache; } @Override protected String getPKDBName() { return "fragmentEntryLinkId"; } @Override protected String getSelectSQL() { return _SQL_SELECT_FRAGMENTENTRYLINK; } @Override public Set getCTColumnNames( CTColumnResolutionType ctColumnResolutionType) { return _ctColumnNamesMap.getOrDefault( ctColumnResolutionType, Collections.emptySet()); } @Override public List getMappingTableNames() { return _mappingTableNames; } @Override public Map getTableColumnsMap() { return FragmentEntryLinkModelImpl.TABLE_COLUMNS_MAP; } @Override public String getTableName() { return "FragmentEntryLink"; } @Override public List getUniqueIndexColumnNames() { return _uniqueIndexColumnNames; } private static final Map> _ctColumnNamesMap = new EnumMap>( CTColumnResolutionType.class); private static final List _mappingTableNames = new ArrayList(); private static final List _uniqueIndexColumnNames = new ArrayList(); static { Set ctControlColumnNames = new HashSet(); Set ctIgnoreColumnNames = new HashSet(); Set ctMergeColumnNames = new HashSet(); Set ctStrictColumnNames = new HashSet(); ctControlColumnNames.add("mvccVersion"); ctControlColumnNames.add("ctCollectionId"); ctStrictColumnNames.add("uuid_"); ctStrictColumnNames.add("externalReferenceCode"); ctStrictColumnNames.add("groupId"); ctStrictColumnNames.add("companyId"); ctMergeColumnNames.add("userId"); ctMergeColumnNames.add("userName"); ctStrictColumnNames.add("createDate"); ctIgnoreColumnNames.add("modifiedDate"); ctStrictColumnNames.add("originalFragmentEntryLinkId"); ctStrictColumnNames.add("fragmentEntryId"); ctStrictColumnNames.add("segmentsExperienceId"); ctStrictColumnNames.add("classNameId"); ctStrictColumnNames.add("classPK"); ctStrictColumnNames.add("plid"); ctMergeColumnNames.add("css"); ctMergeColumnNames.add("html"); ctMergeColumnNames.add("js"); ctMergeColumnNames.add("configuration"); ctStrictColumnNames.add("deleted"); ctMergeColumnNames.add("editableValues"); ctStrictColumnNames.add("namespace"); ctStrictColumnNames.add("position"); ctStrictColumnNames.add("rendererKey"); ctStrictColumnNames.add("type_"); ctMergeColumnNames.add("lastPropagationDate"); ctMergeColumnNames.add("lastPublishDate"); _ctColumnNamesMap.put( CTColumnResolutionType.CONTROL, ctControlColumnNames); _ctColumnNamesMap.put( CTColumnResolutionType.IGNORE, ctIgnoreColumnNames); _ctColumnNamesMap.put(CTColumnResolutionType.MERGE, ctMergeColumnNames); _ctColumnNamesMap.put( CTColumnResolutionType.PK, Collections.singleton("fragmentEntryLinkId")); _ctColumnNamesMap.put( CTColumnResolutionType.STRICT, ctStrictColumnNames); _uniqueIndexColumnNames.add(new String[] {"uuid_", "groupId"}); _uniqueIndexColumnNames.add( new String[] {"externalReferenceCode", "groupId"}); } /** * Initializes the fragment entry link persistence. */ @Activate public void activate() { _valueObjectFinderCacheListThreshold = GetterUtil.getInteger( PropsUtil.get(PropsKeys.VALUE_OBJECT_FINDER_CACHE_LIST_THRESHOLD)); _finderPathWithPaginationFindAll = new FinderPath( FINDER_CLASS_NAME_LIST_WITH_PAGINATION, "findAll", new String[0], new String[0], true); _finderPathWithoutPaginationFindAll = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "findAll", new String[0], new String[0], true); _finderPathCountAll = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "countAll", new String[0], new String[0], false); _finderPathWithPaginationFindByUuid = new FinderPath( FINDER_CLASS_NAME_LIST_WITH_PAGINATION, "findByUuid", new String[] { String.class.getName(), Integer.class.getName(), Integer.class.getName(), OrderByComparator.class.getName() }, new String[] {"uuid_"}, true); _finderPathWithoutPaginationFindByUuid = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "findByUuid", new String[] {String.class.getName()}, new String[] {"uuid_"}, true); _finderPathCountByUuid = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "countByUuid", new String[] {String.class.getName()}, new String[] {"uuid_"}, false); _finderPathFetchByUUID_G = new FinderPath( FINDER_CLASS_NAME_ENTITY, "fetchByUUID_G", new String[] {String.class.getName(), Long.class.getName()}, new String[] {"uuid_", "groupId"}, true); _finderPathCountByUUID_G = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "countByUUID_G", new String[] {String.class.getName(), Long.class.getName()}, new String[] {"uuid_", "groupId"}, false); _finderPathWithPaginationFindByUuid_C = new FinderPath( FINDER_CLASS_NAME_LIST_WITH_PAGINATION, "findByUuid_C", new String[] { String.class.getName(), Long.class.getName(), Integer.class.getName(), Integer.class.getName(), OrderByComparator.class.getName() }, new String[] {"uuid_", "companyId"}, true); _finderPathWithoutPaginationFindByUuid_C = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "findByUuid_C", new String[] {String.class.getName(), Long.class.getName()}, new String[] {"uuid_", "companyId"}, true); _finderPathCountByUuid_C = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "countByUuid_C", new String[] {String.class.getName(), Long.class.getName()}, new String[] {"uuid_", "companyId"}, false); _finderPathWithPaginationFindByGroupId = new FinderPath( FINDER_CLASS_NAME_LIST_WITH_PAGINATION, "findByGroupId", new String[] { Long.class.getName(), Integer.class.getName(), Integer.class.getName(), OrderByComparator.class.getName() }, new String[] {"groupId"}, true); _finderPathWithoutPaginationFindByGroupId = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "findByGroupId", new String[] {Long.class.getName()}, new String[] {"groupId"}, true); _finderPathCountByGroupId = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "countByGroupId", new String[] {Long.class.getName()}, new String[] {"groupId"}, false); _finderPathWithPaginationFindByFragmentEntryId = new FinderPath( FINDER_CLASS_NAME_LIST_WITH_PAGINATION, "findByFragmentEntryId", new String[] { Long.class.getName(), Integer.class.getName(), Integer.class.getName(), OrderByComparator.class.getName() }, new String[] {"fragmentEntryId"}, true); _finderPathWithoutPaginationFindByFragmentEntryId = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "findByFragmentEntryId", new String[] {Long.class.getName()}, new String[] {"fragmentEntryId"}, true); _finderPathCountByFragmentEntryId = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "countByFragmentEntryId", new String[] {Long.class.getName()}, new String[] {"fragmentEntryId"}, false); _finderPathWithPaginationCountByFragmentEntryId = new FinderPath( FINDER_CLASS_NAME_LIST_WITH_PAGINATION, "countByFragmentEntryId", new String[] {Long.class.getName()}, new String[] {"fragmentEntryId"}, false); _finderPathWithPaginationFindByRendererKey = new FinderPath( FINDER_CLASS_NAME_LIST_WITH_PAGINATION, "findByRendererKey", new String[] { String.class.getName(), Integer.class.getName(), Integer.class.getName(), OrderByComparator.class.getName() }, new String[] {"rendererKey"}, true); _finderPathWithoutPaginationFindByRendererKey = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "findByRendererKey", new String[] {String.class.getName()}, new String[] {"rendererKey"}, true); _finderPathCountByRendererKey = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "countByRendererKey", new String[] {String.class.getName()}, new String[] {"rendererKey"}, false); _finderPathWithPaginationFindByG_F = new FinderPath( FINDER_CLASS_NAME_LIST_WITH_PAGINATION, "findByG_F", new String[] { Long.class.getName(), Long.class.getName(), Integer.class.getName(), Integer.class.getName(), OrderByComparator.class.getName() }, new String[] {"groupId", "fragmentEntryId"}, true); _finderPathWithoutPaginationFindByG_F = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "findByG_F", new String[] {Long.class.getName(), Long.class.getName()}, new String[] {"groupId", "fragmentEntryId"}, true); _finderPathCountByG_F = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "countByG_F", new String[] {Long.class.getName(), Long.class.getName()}, new String[] {"groupId", "fragmentEntryId"}, false); _finderPathWithPaginationFindByG_P = new FinderPath( FINDER_CLASS_NAME_LIST_WITH_PAGINATION, "findByG_P", new String[] { Long.class.getName(), Long.class.getName(), Integer.class.getName(), Integer.class.getName(), OrderByComparator.class.getName() }, new String[] {"groupId", "plid"}, true); _finderPathWithoutPaginationFindByG_P = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "findByG_P", new String[] {Long.class.getName(), Long.class.getName()}, new String[] {"groupId", "plid"}, true); _finderPathCountByG_P = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "countByG_P", new String[] {Long.class.getName(), Long.class.getName()}, new String[] {"groupId", "plid"}, false); _finderPathWithPaginationFindByC_R = new FinderPath( FINDER_CLASS_NAME_LIST_WITH_PAGINATION, "findByC_R", new String[] { Long.class.getName(), String.class.getName(), Integer.class.getName(), Integer.class.getName(), OrderByComparator.class.getName() }, new String[] {"companyId", "rendererKey"}, true); _finderPathWithoutPaginationFindByC_R = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "findByC_R", new String[] {Long.class.getName(), String.class.getName()}, new String[] {"companyId", "rendererKey"}, true); _finderPathCountByC_R = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "countByC_R", new String[] {Long.class.getName(), String.class.getName()}, new String[] {"companyId", "rendererKey"}, false); _finderPathWithPaginationCountByC_R = new FinderPath( FINDER_CLASS_NAME_LIST_WITH_PAGINATION, "countByC_R", new String[] {Long.class.getName(), String.class.getName()}, new String[] {"companyId", "rendererKey"}, false); _finderPathWithPaginationFindByF_D = new FinderPath( FINDER_CLASS_NAME_LIST_WITH_PAGINATION, "findByF_D", new String[] { Long.class.getName(), Boolean.class.getName(), Integer.class.getName(), Integer.class.getName(), OrderByComparator.class.getName() }, new String[] {"fragmentEntryId", "deleted"}, true); _finderPathWithoutPaginationFindByF_D = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "findByF_D", new String[] {Long.class.getName(), Boolean.class.getName()}, new String[] {"fragmentEntryId", "deleted"}, true); _finderPathCountByF_D = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "countByF_D", new String[] {Long.class.getName(), Boolean.class.getName()}, new String[] {"fragmentEntryId", "deleted"}, false); _finderPathWithPaginationCountByF_D = new FinderPath( FINDER_CLASS_NAME_LIST_WITH_PAGINATION, "countByF_D", new String[] {Long.class.getName(), Boolean.class.getName()}, new String[] {"fragmentEntryId", "deleted"}, false); _finderPathWithPaginationFindByG_OFELI_P = new FinderPath( FINDER_CLASS_NAME_LIST_WITH_PAGINATION, "findByG_OFELI_P", new String[] { Long.class.getName(), Long.class.getName(), Long.class.getName(), Integer.class.getName(), Integer.class.getName(), OrderByComparator.class.getName() }, new String[] {"groupId", "originalFragmentEntryLinkId", "plid"}, true); _finderPathWithoutPaginationFindByG_OFELI_P = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "findByG_OFELI_P", new String[] { Long.class.getName(), Long.class.getName(), Long.class.getName() }, new String[] {"groupId", "originalFragmentEntryLinkId", "plid"}, true); _finderPathCountByG_OFELI_P = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "countByG_OFELI_P", new String[] { Long.class.getName(), Long.class.getName(), Long.class.getName() }, new String[] {"groupId", "originalFragmentEntryLinkId", "plid"}, false); _finderPathWithPaginationFindByG_F_C = new FinderPath( FINDER_CLASS_NAME_LIST_WITH_PAGINATION, "findByG_F_C", new String[] { Long.class.getName(), Long.class.getName(), Long.class.getName(), Integer.class.getName(), Integer.class.getName(), OrderByComparator.class.getName() }, new String[] {"groupId", "fragmentEntryId", "classNameId"}, true); _finderPathWithoutPaginationFindByG_F_C = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "findByG_F_C", new String[] { Long.class.getName(), Long.class.getName(), Long.class.getName() }, new String[] {"groupId", "fragmentEntryId", "classNameId"}, true); _finderPathCountByG_F_C = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "countByG_F_C", new String[] { Long.class.getName(), Long.class.getName(), Long.class.getName() }, new String[] {"groupId", "fragmentEntryId", "classNameId"}, false); _finderPathWithPaginationFindByG_F_P = new FinderPath( FINDER_CLASS_NAME_LIST_WITH_PAGINATION, "findByG_F_P", new String[] { Long.class.getName(), Long.class.getName(), Long.class.getName(), Integer.class.getName(), Integer.class.getName(), OrderByComparator.class.getName() }, new String[] {"groupId", "fragmentEntryId", "plid"}, true); _finderPathWithoutPaginationFindByG_F_P = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "findByG_F_P", new String[] { Long.class.getName(), Long.class.getName(), Long.class.getName() }, new String[] {"groupId", "fragmentEntryId", "plid"}, true); _finderPathCountByG_F_P = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "countByG_F_P", new String[] { Long.class.getName(), Long.class.getName(), Long.class.getName() }, new String[] {"groupId", "fragmentEntryId", "plid"}, false); _finderPathWithPaginationFindByG_S_P = new FinderPath( FINDER_CLASS_NAME_LIST_WITH_PAGINATION, "findByG_S_P", new String[] { Long.class.getName(), Long.class.getName(), Long.class.getName(), Integer.class.getName(), Integer.class.getName(), OrderByComparator.class.getName() }, new String[] {"groupId", "segmentsExperienceId", "plid"}, true); _finderPathWithoutPaginationFindByG_S_P = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "findByG_S_P", new String[] { Long.class.getName(), Long.class.getName(), Long.class.getName() }, new String[] {"groupId", "segmentsExperienceId", "plid"}, true); _finderPathCountByG_S_P = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "countByG_S_P", new String[] { Long.class.getName(), Long.class.getName(), Long.class.getName() }, new String[] {"groupId", "segmentsExperienceId", "plid"}, false); _finderPathWithPaginationCountByG_S_P = new FinderPath( FINDER_CLASS_NAME_LIST_WITH_PAGINATION, "countByG_S_P", new String[] { Long.class.getName(), Long.class.getName(), Long.class.getName() }, new String[] {"groupId", "segmentsExperienceId", "plid"}, false); _finderPathWithPaginationFindByG_C_C = new FinderPath( FINDER_CLASS_NAME_LIST_WITH_PAGINATION, "findByG_C_C", new String[] { Long.class.getName(), Long.class.getName(), Long.class.getName(), Integer.class.getName(), Integer.class.getName(), OrderByComparator.class.getName() }, new String[] {"groupId", "classNameId", "classPK"}, true); _finderPathWithoutPaginationFindByG_C_C = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "findByG_C_C", new String[] { Long.class.getName(), Long.class.getName(), Long.class.getName() }, new String[] {"groupId", "classNameId", "classPK"}, true); _finderPathCountByG_C_C = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "countByG_C_C", new String[] { Long.class.getName(), Long.class.getName(), Long.class.getName() }, new String[] {"groupId", "classNameId", "classPK"}, false); _finderPathWithPaginationFindByG_P_D = new FinderPath( FINDER_CLASS_NAME_LIST_WITH_PAGINATION, "findByG_P_D", new String[] { Long.class.getName(), Long.class.getName(), Boolean.class.getName(), Integer.class.getName(), Integer.class.getName(), OrderByComparator.class.getName() }, new String[] {"groupId", "plid", "deleted"}, true); _finderPathWithoutPaginationFindByG_P_D = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "findByG_P_D", new String[] { Long.class.getName(), Long.class.getName(), Boolean.class.getName() }, new String[] {"groupId", "plid", "deleted"}, true); _finderPathCountByG_P_D = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "countByG_P_D", new String[] { Long.class.getName(), Long.class.getName(), Boolean.class.getName() }, new String[] {"groupId", "plid", "deleted"}, false); _finderPathWithPaginationFindByG_F_C_C = new FinderPath( FINDER_CLASS_NAME_LIST_WITH_PAGINATION, "findByG_F_C_C", new String[] { Long.class.getName(), Long.class.getName(), Long.class.getName(), Long.class.getName(), Integer.class.getName(), Integer.class.getName(), OrderByComparator.class.getName() }, new String[] { "groupId", "fragmentEntryId", "classNameId", "classPK" }, true); _finderPathWithoutPaginationFindByG_F_C_C = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "findByG_F_C_C", new String[] { Long.class.getName(), Long.class.getName(), Long.class.getName(), Long.class.getName() }, new String[] { "groupId", "fragmentEntryId", "classNameId", "classPK" }, true); _finderPathCountByG_F_C_C = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "countByG_F_C_C", new String[] { Long.class.getName(), Long.class.getName(), Long.class.getName(), Long.class.getName() }, new String[] { "groupId", "fragmentEntryId", "classNameId", "classPK" }, false); _finderPathWithPaginationFindByG_S_C_C = new FinderPath( FINDER_CLASS_NAME_LIST_WITH_PAGINATION, "findByG_S_C_C", new String[] { Long.class.getName(), Long.class.getName(), Long.class.getName(), Long.class.getName(), Integer.class.getName(), Integer.class.getName(), OrderByComparator.class.getName() }, new String[] { "groupId", "segmentsExperienceId", "classNameId", "classPK" }, true); _finderPathWithoutPaginationFindByG_S_C_C = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "findByG_S_C_C", new String[] { Long.class.getName(), Long.class.getName(), Long.class.getName(), Long.class.getName() }, new String[] { "groupId", "segmentsExperienceId", "classNameId", "classPK" }, true); _finderPathCountByG_S_C_C = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "countByG_S_C_C", new String[] { Long.class.getName(), Long.class.getName(), Long.class.getName(), Long.class.getName() }, new String[] { "groupId", "segmentsExperienceId", "classNameId", "classPK" }, false); _finderPathWithPaginationFindByG_S_P_D = new FinderPath( FINDER_CLASS_NAME_LIST_WITH_PAGINATION, "findByG_S_P_D", new String[] { Long.class.getName(), Long.class.getName(), Long.class.getName(), Boolean.class.getName(), Integer.class.getName(), Integer.class.getName(), OrderByComparator.class.getName() }, new String[] {"groupId", "segmentsExperienceId", "plid", "deleted"}, true); _finderPathWithoutPaginationFindByG_S_P_D = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "findByG_S_P_D", new String[] { Long.class.getName(), Long.class.getName(), Long.class.getName(), Boolean.class.getName() }, new String[] {"groupId", "segmentsExperienceId", "plid", "deleted"}, true); _finderPathCountByG_S_P_D = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "countByG_S_P_D", new String[] { Long.class.getName(), Long.class.getName(), Long.class.getName(), Boolean.class.getName() }, new String[] {"groupId", "segmentsExperienceId", "plid", "deleted"}, false); _finderPathWithPaginationCountByG_S_P_D = new FinderPath( FINDER_CLASS_NAME_LIST_WITH_PAGINATION, "countByG_S_P_D", new String[] { Long.class.getName(), Long.class.getName(), Long.class.getName(), Boolean.class.getName() }, new String[] {"groupId", "segmentsExperienceId", "plid", "deleted"}, false); _finderPathWithPaginationFindByG_S_P_R = new FinderPath( FINDER_CLASS_NAME_LIST_WITH_PAGINATION, "findByG_S_P_R", new String[] { Long.class.getName(), Long.class.getName(), Long.class.getName(), String.class.getName(), Integer.class.getName(), Integer.class.getName(), OrderByComparator.class.getName() }, new String[] { "groupId", "segmentsExperienceId", "plid", "rendererKey" }, true); _finderPathWithoutPaginationFindByG_S_P_R = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "findByG_S_P_R", new String[] { Long.class.getName(), Long.class.getName(), Long.class.getName(), String.class.getName() }, new String[] { "groupId", "segmentsExperienceId", "plid", "rendererKey" }, true); _finderPathCountByG_S_P_R = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "countByG_S_P_R", new String[] { Long.class.getName(), Long.class.getName(), Long.class.getName(), String.class.getName() }, new String[] { "groupId", "segmentsExperienceId", "plid", "rendererKey" }, false); _finderPathFetchByERC_G = new FinderPath( FINDER_CLASS_NAME_ENTITY, "fetchByERC_G", new String[] {String.class.getName(), Long.class.getName()}, new String[] {"externalReferenceCode", "groupId"}, true); _finderPathCountByERC_G = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "countByERC_G", new String[] {String.class.getName(), Long.class.getName()}, new String[] {"externalReferenceCode", "groupId"}, false); FragmentEntryLinkUtil.setPersistence(this); } @Deactivate public void deactivate() { FragmentEntryLinkUtil.setPersistence(null); entityCache.removeCache(FragmentEntryLinkImpl.class.getName()); } @Override @Reference( target = FragmentPersistenceConstants.SERVICE_CONFIGURATION_FILTER, unbind = "-" ) public void setConfiguration(Configuration configuration) { } @Override @Reference( target = FragmentPersistenceConstants.ORIGIN_BUNDLE_SYMBOLIC_NAME_FILTER, unbind = "-" ) public void setDataSource(DataSource dataSource) { super.setDataSource(dataSource); } @Override @Reference( target = FragmentPersistenceConstants.ORIGIN_BUNDLE_SYMBOLIC_NAME_FILTER, unbind = "-" ) public void setSessionFactory(SessionFactory sessionFactory) { super.setSessionFactory(sessionFactory); } @Reference protected CTPersistenceHelper ctPersistenceHelper; @Reference protected EntityCache entityCache; @Reference protected FinderCache finderCache; private static final String _SQL_SELECT_FRAGMENTENTRYLINK = "SELECT fragmentEntryLink FROM FragmentEntryLink fragmentEntryLink"; private static final String _SQL_SELECT_FRAGMENTENTRYLINK_WHERE = "SELECT fragmentEntryLink FROM FragmentEntryLink fragmentEntryLink WHERE "; private static final String _SQL_COUNT_FRAGMENTENTRYLINK = "SELECT COUNT(fragmentEntryLink) FROM FragmentEntryLink fragmentEntryLink"; private static final String _SQL_COUNT_FRAGMENTENTRYLINK_WHERE = "SELECT COUNT(fragmentEntryLink) FROM FragmentEntryLink fragmentEntryLink WHERE "; private static final String _ORDER_BY_ENTITY_ALIAS = "fragmentEntryLink."; private static final String _NO_SUCH_ENTITY_WITH_PRIMARY_KEY = "No FragmentEntryLink exists with the primary key "; private static final String _NO_SUCH_ENTITY_WITH_KEY = "No FragmentEntryLink exists with the key {"; private static final Log _log = LogFactoryUtil.getLog( FragmentEntryLinkPersistenceImpl.class); private static final Set _badColumnNames = SetUtil.fromArray( new String[] {"uuid", "type"}); @Override protected FinderCache getFinderCache() { return finderCache; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy