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

com.liferay.asset.link.service.persistence.impl.AssetLinkPersistenceImpl Maven / Gradle / Ivy

/**
 * SPDX-FileCopyrightText: (c) 2023 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.asset.link.service.persistence.impl;

import com.liferay.asset.link.exception.NoSuchLinkException;
import com.liferay.asset.link.model.AssetLink;
import com.liferay.asset.link.model.AssetLinkTable;
import com.liferay.asset.link.model.impl.AssetLinkImpl;
import com.liferay.asset.link.model.impl.AssetLinkModelImpl;
import com.liferay.asset.link.service.persistence.AssetLinkPersistence;
import com.liferay.asset.link.service.persistence.AssetLinkUtil;
import com.liferay.asset.link.service.persistence.impl.constants.AssetPersistenceConstants;
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.log.Log;
import com.liferay.portal.kernel.log.LogFactoryUtil;
import com.liferay.portal.kernel.security.auth.CompanyThreadLocal;
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.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 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.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 asset link service.
 *
 * 

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

* * @author Brian Wing Shun Chan * @generated */ @Component(service = AssetLinkPersistence.class) public class AssetLinkPersistenceImpl extends BasePersistenceImpl implements AssetLinkPersistence { /* * NOTE FOR DEVELOPERS: * * Never modify or reference this class directly. Always use AssetLinkUtil to access the asset link persistence. Modify service.xml and rerun ServiceBuilder to regenerate this class. */ public static final String FINDER_CLASS_NAME_ENTITY = AssetLinkImpl.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 _finderPathWithPaginationFindByEntryId1; private FinderPath _finderPathWithoutPaginationFindByEntryId1; private FinderPath _finderPathCountByEntryId1; /** * Returns all the asset links where entryId1 = ?. * * @param entryId1 the entry id1 * @return the matching asset links */ @Override public List findByEntryId1(long entryId1) { return findByEntryId1( entryId1, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null); } /** * Returns a range of all the asset links where entryId1 = ?. * *

* 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 AssetLinkModelImpl. *

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

* 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 AssetLinkModelImpl. *

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

* 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 AssetLinkModelImpl. *

* * @param entryId1 the entry id1 * @param start the lower bound of the range of asset links * @param end the upper bound of the range of asset 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 asset links */ @Override public List findByEntryId1( long entryId1, int start, int end, OrderByComparator orderByComparator, boolean useFinderCache) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( AssetLink.class)) { FinderPath finderPath = null; Object[] finderArgs = null; if ((start == QueryUtil.ALL_POS) && (end == QueryUtil.ALL_POS) && (orderByComparator == null)) { if (useFinderCache) { finderPath = _finderPathWithoutPaginationFindByEntryId1; finderArgs = new Object[] {entryId1}; } } else if (useFinderCache) { finderPath = _finderPathWithPaginationFindByEntryId1; finderArgs = new Object[] { entryId1, start, end, orderByComparator }; } List list = null; if (useFinderCache) { list = (List)finderCache.getResult( finderPath, finderArgs, this); if ((list != null) && !list.isEmpty()) { for (AssetLink assetLink : list) { if (entryId1 != assetLink.getEntryId1()) { 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_ASSETLINK_WHERE); sb.append(_FINDER_COLUMN_ENTRYID1_ENTRYID1_2); if (orderByComparator != null) { appendOrderByComparator( sb, _ORDER_BY_ENTITY_ALIAS, orderByComparator); } else { sb.append(AssetLinkModelImpl.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(entryId1); 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 asset link in the ordered set where entryId1 = ?. * * @param entryId1 the entry id1 * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching asset link * @throws NoSuchLinkException if a matching asset link could not be found */ @Override public AssetLink findByEntryId1_First( long entryId1, OrderByComparator orderByComparator) throws NoSuchLinkException { AssetLink assetLink = fetchByEntryId1_First( entryId1, orderByComparator); if (assetLink != null) { return assetLink; } StringBundler sb = new StringBundler(4); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("entryId1="); sb.append(entryId1); sb.append("}"); throw new NoSuchLinkException(sb.toString()); } /** * Returns the first asset link in the ordered set where entryId1 = ?. * * @param entryId1 the entry id1 * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching asset link, or null if a matching asset link could not be found */ @Override public AssetLink fetchByEntryId1_First( long entryId1, OrderByComparator orderByComparator) { List list = findByEntryId1( entryId1, 0, 1, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the last asset link in the ordered set where entryId1 = ?. * * @param entryId1 the entry id1 * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching asset link * @throws NoSuchLinkException if a matching asset link could not be found */ @Override public AssetLink findByEntryId1_Last( long entryId1, OrderByComparator orderByComparator) throws NoSuchLinkException { AssetLink assetLink = fetchByEntryId1_Last(entryId1, orderByComparator); if (assetLink != null) { return assetLink; } StringBundler sb = new StringBundler(4); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("entryId1="); sb.append(entryId1); sb.append("}"); throw new NoSuchLinkException(sb.toString()); } /** * Returns the last asset link in the ordered set where entryId1 = ?. * * @param entryId1 the entry id1 * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching asset link, or null if a matching asset link could not be found */ @Override public AssetLink fetchByEntryId1_Last( long entryId1, OrderByComparator orderByComparator) { int count = countByEntryId1(entryId1); if (count == 0) { return null; } List list = findByEntryId1( entryId1, count - 1, count, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the asset links before and after the current asset link in the ordered set where entryId1 = ?. * * @param linkId the primary key of the current asset link * @param entryId1 the entry id1 * @param orderByComparator the comparator to order the set by (optionally null) * @return the previous, current, and next asset link * @throws NoSuchLinkException if a asset link with the primary key could not be found */ @Override public AssetLink[] findByEntryId1_PrevAndNext( long linkId, long entryId1, OrderByComparator orderByComparator) throws NoSuchLinkException { AssetLink assetLink = findByPrimaryKey(linkId); Session session = null; try { session = openSession(); AssetLink[] array = new AssetLinkImpl[3]; array[0] = getByEntryId1_PrevAndNext( session, assetLink, entryId1, orderByComparator, true); array[1] = assetLink; array[2] = getByEntryId1_PrevAndNext( session, assetLink, entryId1, orderByComparator, false); return array; } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } protected AssetLink getByEntryId1_PrevAndNext( Session session, AssetLink assetLink, long entryId1, 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_ASSETLINK_WHERE); sb.append(_FINDER_COLUMN_ENTRYID1_ENTRYID1_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(AssetLinkModelImpl.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(entryId1); if (orderByComparator != null) { for (Object orderByConditionValue : orderByComparator.getOrderByConditionValues(assetLink)) { queryPos.add(orderByConditionValue); } } List list = query.list(); if (list.size() == 2) { return list.get(1); } else { return null; } } /** * Removes all the asset links where entryId1 = ? from the database. * * @param entryId1 the entry id1 */ @Override public void removeByEntryId1(long entryId1) { for (AssetLink assetLink : findByEntryId1( entryId1, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null)) { remove(assetLink); } } /** * Returns the number of asset links where entryId1 = ?. * * @param entryId1 the entry id1 * @return the number of matching asset links */ @Override public int countByEntryId1(long entryId1) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( AssetLink.class)) { FinderPath finderPath = _finderPathCountByEntryId1; Object[] finderArgs = new Object[] {entryId1}; Long count = (Long)finderCache.getResult( finderPath, finderArgs, this); if (count == null) { StringBundler sb = new StringBundler(2); sb.append(_SQL_COUNT_ASSETLINK_WHERE); sb.append(_FINDER_COLUMN_ENTRYID1_ENTRYID1_2); String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(entryId1); 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_ENTRYID1_ENTRYID1_2 = "assetLink.entryId1 = ?"; private FinderPath _finderPathWithPaginationFindByEntryId2; private FinderPath _finderPathWithoutPaginationFindByEntryId2; private FinderPath _finderPathCountByEntryId2; /** * Returns all the asset links where entryId2 = ?. * * @param entryId2 the entry id2 * @return the matching asset links */ @Override public List findByEntryId2(long entryId2) { return findByEntryId2( entryId2, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null); } /** * Returns a range of all the asset links where entryId2 = ?. * *

* 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 AssetLinkModelImpl. *

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

* 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 AssetLinkModelImpl. *

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

* 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 AssetLinkModelImpl. *

* * @param entryId2 the entry id2 * @param start the lower bound of the range of asset links * @param end the upper bound of the range of asset 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 asset links */ @Override public List findByEntryId2( long entryId2, int start, int end, OrderByComparator orderByComparator, boolean useFinderCache) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( AssetLink.class)) { FinderPath finderPath = null; Object[] finderArgs = null; if ((start == QueryUtil.ALL_POS) && (end == QueryUtil.ALL_POS) && (orderByComparator == null)) { if (useFinderCache) { finderPath = _finderPathWithoutPaginationFindByEntryId2; finderArgs = new Object[] {entryId2}; } } else if (useFinderCache) { finderPath = _finderPathWithPaginationFindByEntryId2; finderArgs = new Object[] { entryId2, start, end, orderByComparator }; } List list = null; if (useFinderCache) { list = (List)finderCache.getResult( finderPath, finderArgs, this); if ((list != null) && !list.isEmpty()) { for (AssetLink assetLink : list) { if (entryId2 != assetLink.getEntryId2()) { 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_ASSETLINK_WHERE); sb.append(_FINDER_COLUMN_ENTRYID2_ENTRYID2_2); if (orderByComparator != null) { appendOrderByComparator( sb, _ORDER_BY_ENTITY_ALIAS, orderByComparator); } else { sb.append(AssetLinkModelImpl.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(entryId2); 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 asset link in the ordered set where entryId2 = ?. * * @param entryId2 the entry id2 * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching asset link * @throws NoSuchLinkException if a matching asset link could not be found */ @Override public AssetLink findByEntryId2_First( long entryId2, OrderByComparator orderByComparator) throws NoSuchLinkException { AssetLink assetLink = fetchByEntryId2_First( entryId2, orderByComparator); if (assetLink != null) { return assetLink; } StringBundler sb = new StringBundler(4); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("entryId2="); sb.append(entryId2); sb.append("}"); throw new NoSuchLinkException(sb.toString()); } /** * Returns the first asset link in the ordered set where entryId2 = ?. * * @param entryId2 the entry id2 * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching asset link, or null if a matching asset link could not be found */ @Override public AssetLink fetchByEntryId2_First( long entryId2, OrderByComparator orderByComparator) { List list = findByEntryId2( entryId2, 0, 1, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the last asset link in the ordered set where entryId2 = ?. * * @param entryId2 the entry id2 * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching asset link * @throws NoSuchLinkException if a matching asset link could not be found */ @Override public AssetLink findByEntryId2_Last( long entryId2, OrderByComparator orderByComparator) throws NoSuchLinkException { AssetLink assetLink = fetchByEntryId2_Last(entryId2, orderByComparator); if (assetLink != null) { return assetLink; } StringBundler sb = new StringBundler(4); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("entryId2="); sb.append(entryId2); sb.append("}"); throw new NoSuchLinkException(sb.toString()); } /** * Returns the last asset link in the ordered set where entryId2 = ?. * * @param entryId2 the entry id2 * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching asset link, or null if a matching asset link could not be found */ @Override public AssetLink fetchByEntryId2_Last( long entryId2, OrderByComparator orderByComparator) { int count = countByEntryId2(entryId2); if (count == 0) { return null; } List list = findByEntryId2( entryId2, count - 1, count, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the asset links before and after the current asset link in the ordered set where entryId2 = ?. * * @param linkId the primary key of the current asset link * @param entryId2 the entry id2 * @param orderByComparator the comparator to order the set by (optionally null) * @return the previous, current, and next asset link * @throws NoSuchLinkException if a asset link with the primary key could not be found */ @Override public AssetLink[] findByEntryId2_PrevAndNext( long linkId, long entryId2, OrderByComparator orderByComparator) throws NoSuchLinkException { AssetLink assetLink = findByPrimaryKey(linkId); Session session = null; try { session = openSession(); AssetLink[] array = new AssetLinkImpl[3]; array[0] = getByEntryId2_PrevAndNext( session, assetLink, entryId2, orderByComparator, true); array[1] = assetLink; array[2] = getByEntryId2_PrevAndNext( session, assetLink, entryId2, orderByComparator, false); return array; } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } protected AssetLink getByEntryId2_PrevAndNext( Session session, AssetLink assetLink, long entryId2, 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_ASSETLINK_WHERE); sb.append(_FINDER_COLUMN_ENTRYID2_ENTRYID2_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(AssetLinkModelImpl.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(entryId2); if (orderByComparator != null) { for (Object orderByConditionValue : orderByComparator.getOrderByConditionValues(assetLink)) { queryPos.add(orderByConditionValue); } } List list = query.list(); if (list.size() == 2) { return list.get(1); } else { return null; } } /** * Removes all the asset links where entryId2 = ? from the database. * * @param entryId2 the entry id2 */ @Override public void removeByEntryId2(long entryId2) { for (AssetLink assetLink : findByEntryId2( entryId2, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null)) { remove(assetLink); } } /** * Returns the number of asset links where entryId2 = ?. * * @param entryId2 the entry id2 * @return the number of matching asset links */ @Override public int countByEntryId2(long entryId2) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( AssetLink.class)) { FinderPath finderPath = _finderPathCountByEntryId2; Object[] finderArgs = new Object[] {entryId2}; Long count = (Long)finderCache.getResult( finderPath, finderArgs, this); if (count == null) { StringBundler sb = new StringBundler(2); sb.append(_SQL_COUNT_ASSETLINK_WHERE); sb.append(_FINDER_COLUMN_ENTRYID2_ENTRYID2_2); String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(entryId2); 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_ENTRYID2_ENTRYID2_2 = "assetLink.entryId2 = ?"; private FinderPath _finderPathWithPaginationFindByE_E; private FinderPath _finderPathWithoutPaginationFindByE_E; private FinderPath _finderPathCountByE_E; /** * Returns all the asset links where entryId1 = ? and entryId2 = ?. * * @param entryId1 the entry id1 * @param entryId2 the entry id2 * @return the matching asset links */ @Override public List findByE_E(long entryId1, long entryId2) { return findByE_E( entryId1, entryId2, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null); } /** * Returns a range of all the asset links where entryId1 = ? and entryId2 = ?. * *

* 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 AssetLinkModelImpl. *

* * @param entryId1 the entry id1 * @param entryId2 the entry id2 * @param start the lower bound of the range of asset links * @param end the upper bound of the range of asset links (not inclusive) * @return the range of matching asset links */ @Override public List findByE_E( long entryId1, long entryId2, int start, int end) { return findByE_E(entryId1, entryId2, start, end, null); } /** * Returns an ordered range of all the asset links where entryId1 = ? and entryId2 = ?. * *

* 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 AssetLinkModelImpl. *

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

* 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 AssetLinkModelImpl. *

* * @param entryId1 the entry id1 * @param entryId2 the entry id2 * @param start the lower bound of the range of asset links * @param end the upper bound of the range of asset 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 asset links */ @Override public List findByE_E( long entryId1, long entryId2, int start, int end, OrderByComparator orderByComparator, boolean useFinderCache) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( AssetLink.class)) { FinderPath finderPath = null; Object[] finderArgs = null; if ((start == QueryUtil.ALL_POS) && (end == QueryUtil.ALL_POS) && (orderByComparator == null)) { if (useFinderCache) { finderPath = _finderPathWithoutPaginationFindByE_E; finderArgs = new Object[] {entryId1, entryId2}; } } else if (useFinderCache) { finderPath = _finderPathWithPaginationFindByE_E; finderArgs = new Object[] { entryId1, entryId2, start, end, orderByComparator }; } List list = null; if (useFinderCache) { list = (List)finderCache.getResult( finderPath, finderArgs, this); if ((list != null) && !list.isEmpty()) { for (AssetLink assetLink : list) { if ((entryId1 != assetLink.getEntryId1()) || (entryId2 != assetLink.getEntryId2())) { 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_ASSETLINK_WHERE); sb.append(_FINDER_COLUMN_E_E_ENTRYID1_2); sb.append(_FINDER_COLUMN_E_E_ENTRYID2_2); if (orderByComparator != null) { appendOrderByComparator( sb, _ORDER_BY_ENTITY_ALIAS, orderByComparator); } else { sb.append(AssetLinkModelImpl.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(entryId1); queryPos.add(entryId2); 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 asset link in the ordered set where entryId1 = ? and entryId2 = ?. * * @param entryId1 the entry id1 * @param entryId2 the entry id2 * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching asset link * @throws NoSuchLinkException if a matching asset link could not be found */ @Override public AssetLink findByE_E_First( long entryId1, long entryId2, OrderByComparator orderByComparator) throws NoSuchLinkException { AssetLink assetLink = fetchByE_E_First( entryId1, entryId2, orderByComparator); if (assetLink != null) { return assetLink; } StringBundler sb = new StringBundler(6); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("entryId1="); sb.append(entryId1); sb.append(", entryId2="); sb.append(entryId2); sb.append("}"); throw new NoSuchLinkException(sb.toString()); } /** * Returns the first asset link in the ordered set where entryId1 = ? and entryId2 = ?. * * @param entryId1 the entry id1 * @param entryId2 the entry id2 * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching asset link, or null if a matching asset link could not be found */ @Override public AssetLink fetchByE_E_First( long entryId1, long entryId2, OrderByComparator orderByComparator) { List list = findByE_E( entryId1, entryId2, 0, 1, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the last asset link in the ordered set where entryId1 = ? and entryId2 = ?. * * @param entryId1 the entry id1 * @param entryId2 the entry id2 * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching asset link * @throws NoSuchLinkException if a matching asset link could not be found */ @Override public AssetLink findByE_E_Last( long entryId1, long entryId2, OrderByComparator orderByComparator) throws NoSuchLinkException { AssetLink assetLink = fetchByE_E_Last( entryId1, entryId2, orderByComparator); if (assetLink != null) { return assetLink; } StringBundler sb = new StringBundler(6); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("entryId1="); sb.append(entryId1); sb.append(", entryId2="); sb.append(entryId2); sb.append("}"); throw new NoSuchLinkException(sb.toString()); } /** * Returns the last asset link in the ordered set where entryId1 = ? and entryId2 = ?. * * @param entryId1 the entry id1 * @param entryId2 the entry id2 * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching asset link, or null if a matching asset link could not be found */ @Override public AssetLink fetchByE_E_Last( long entryId1, long entryId2, OrderByComparator orderByComparator) { int count = countByE_E(entryId1, entryId2); if (count == 0) { return null; } List list = findByE_E( entryId1, entryId2, count - 1, count, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the asset links before and after the current asset link in the ordered set where entryId1 = ? and entryId2 = ?. * * @param linkId the primary key of the current asset link * @param entryId1 the entry id1 * @param entryId2 the entry id2 * @param orderByComparator the comparator to order the set by (optionally null) * @return the previous, current, and next asset link * @throws NoSuchLinkException if a asset link with the primary key could not be found */ @Override public AssetLink[] findByE_E_PrevAndNext( long linkId, long entryId1, long entryId2, OrderByComparator orderByComparator) throws NoSuchLinkException { AssetLink assetLink = findByPrimaryKey(linkId); Session session = null; try { session = openSession(); AssetLink[] array = new AssetLinkImpl[3]; array[0] = getByE_E_PrevAndNext( session, assetLink, entryId1, entryId2, orderByComparator, true); array[1] = assetLink; array[2] = getByE_E_PrevAndNext( session, assetLink, entryId1, entryId2, orderByComparator, false); return array; } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } protected AssetLink getByE_E_PrevAndNext( Session session, AssetLink assetLink, long entryId1, long entryId2, 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_ASSETLINK_WHERE); sb.append(_FINDER_COLUMN_E_E_ENTRYID1_2); sb.append(_FINDER_COLUMN_E_E_ENTRYID2_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(AssetLinkModelImpl.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(entryId1); queryPos.add(entryId2); if (orderByComparator != null) { for (Object orderByConditionValue : orderByComparator.getOrderByConditionValues(assetLink)) { queryPos.add(orderByConditionValue); } } List list = query.list(); if (list.size() == 2) { return list.get(1); } else { return null; } } /** * Removes all the asset links where entryId1 = ? and entryId2 = ? from the database. * * @param entryId1 the entry id1 * @param entryId2 the entry id2 */ @Override public void removeByE_E(long entryId1, long entryId2) { for (AssetLink assetLink : findByE_E( entryId1, entryId2, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null)) { remove(assetLink); } } /** * Returns the number of asset links where entryId1 = ? and entryId2 = ?. * * @param entryId1 the entry id1 * @param entryId2 the entry id2 * @return the number of matching asset links */ @Override public int countByE_E(long entryId1, long entryId2) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( AssetLink.class)) { FinderPath finderPath = _finderPathCountByE_E; Object[] finderArgs = new Object[] {entryId1, entryId2}; Long count = (Long)finderCache.getResult( finderPath, finderArgs, this); if (count == null) { StringBundler sb = new StringBundler(3); sb.append(_SQL_COUNT_ASSETLINK_WHERE); sb.append(_FINDER_COLUMN_E_E_ENTRYID1_2); sb.append(_FINDER_COLUMN_E_E_ENTRYID2_2); String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(entryId1); queryPos.add(entryId2); 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_E_E_ENTRYID1_2 = "assetLink.entryId1 = ? AND "; private static final String _FINDER_COLUMN_E_E_ENTRYID2_2 = "assetLink.entryId2 = ?"; private FinderPath _finderPathWithPaginationFindByE1_T; private FinderPath _finderPathWithoutPaginationFindByE1_T; private FinderPath _finderPathCountByE1_T; /** * Returns all the asset links where entryId1 = ? and type = ?. * * @param entryId1 the entry id1 * @param type the type * @return the matching asset links */ @Override public List findByE1_T(long entryId1, int type) { return findByE1_T( entryId1, type, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null); } /** * Returns a range of all the asset links where entryId1 = ? and type = ?. * *

* 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 AssetLinkModelImpl. *

* * @param entryId1 the entry id1 * @param type the type * @param start the lower bound of the range of asset links * @param end the upper bound of the range of asset links (not inclusive) * @return the range of matching asset links */ @Override public List findByE1_T( long entryId1, int type, int start, int end) { return findByE1_T(entryId1, type, start, end, null); } /** * Returns an ordered range of all the asset links where entryId1 = ? and type = ?. * *

* 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 AssetLinkModelImpl. *

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

* 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 AssetLinkModelImpl. *

* * @param entryId1 the entry id1 * @param type the type * @param start the lower bound of the range of asset links * @param end the upper bound of the range of asset 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 asset links */ @Override public List findByE1_T( long entryId1, int type, int start, int end, OrderByComparator orderByComparator, boolean useFinderCache) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( AssetLink.class)) { FinderPath finderPath = null; Object[] finderArgs = null; if ((start == QueryUtil.ALL_POS) && (end == QueryUtil.ALL_POS) && (orderByComparator == null)) { if (useFinderCache) { finderPath = _finderPathWithoutPaginationFindByE1_T; finderArgs = new Object[] {entryId1, type}; } } else if (useFinderCache) { finderPath = _finderPathWithPaginationFindByE1_T; finderArgs = new Object[] { entryId1, type, start, end, orderByComparator }; } List list = null; if (useFinderCache) { list = (List)finderCache.getResult( finderPath, finderArgs, this); if ((list != null) && !list.isEmpty()) { for (AssetLink assetLink : list) { if ((entryId1 != assetLink.getEntryId1()) || (type != assetLink.getType())) { 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_ASSETLINK_WHERE); sb.append(_FINDER_COLUMN_E1_T_ENTRYID1_2); sb.append(_FINDER_COLUMN_E1_T_TYPE_2); if (orderByComparator != null) { appendOrderByComparator( sb, _ORDER_BY_ENTITY_ALIAS, orderByComparator); } else { sb.append(AssetLinkModelImpl.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(entryId1); queryPos.add(type); 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 asset link in the ordered set where entryId1 = ? and type = ?. * * @param entryId1 the entry id1 * @param type the type * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching asset link * @throws NoSuchLinkException if a matching asset link could not be found */ @Override public AssetLink findByE1_T_First( long entryId1, int type, OrderByComparator orderByComparator) throws NoSuchLinkException { AssetLink assetLink = fetchByE1_T_First( entryId1, type, orderByComparator); if (assetLink != null) { return assetLink; } StringBundler sb = new StringBundler(6); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("entryId1="); sb.append(entryId1); sb.append(", type="); sb.append(type); sb.append("}"); throw new NoSuchLinkException(sb.toString()); } /** * Returns the first asset link in the ordered set where entryId1 = ? and type = ?. * * @param entryId1 the entry id1 * @param type the type * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching asset link, or null if a matching asset link could not be found */ @Override public AssetLink fetchByE1_T_First( long entryId1, int type, OrderByComparator orderByComparator) { List list = findByE1_T( entryId1, type, 0, 1, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the last asset link in the ordered set where entryId1 = ? and type = ?. * * @param entryId1 the entry id1 * @param type the type * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching asset link * @throws NoSuchLinkException if a matching asset link could not be found */ @Override public AssetLink findByE1_T_Last( long entryId1, int type, OrderByComparator orderByComparator) throws NoSuchLinkException { AssetLink assetLink = fetchByE1_T_Last( entryId1, type, orderByComparator); if (assetLink != null) { return assetLink; } StringBundler sb = new StringBundler(6); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("entryId1="); sb.append(entryId1); sb.append(", type="); sb.append(type); sb.append("}"); throw new NoSuchLinkException(sb.toString()); } /** * Returns the last asset link in the ordered set where entryId1 = ? and type = ?. * * @param entryId1 the entry id1 * @param type the type * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching asset link, or null if a matching asset link could not be found */ @Override public AssetLink fetchByE1_T_Last( long entryId1, int type, OrderByComparator orderByComparator) { int count = countByE1_T(entryId1, type); if (count == 0) { return null; } List list = findByE1_T( entryId1, type, count - 1, count, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the asset links before and after the current asset link in the ordered set where entryId1 = ? and type = ?. * * @param linkId the primary key of the current asset link * @param entryId1 the entry id1 * @param type the type * @param orderByComparator the comparator to order the set by (optionally null) * @return the previous, current, and next asset link * @throws NoSuchLinkException if a asset link with the primary key could not be found */ @Override public AssetLink[] findByE1_T_PrevAndNext( long linkId, long entryId1, int type, OrderByComparator orderByComparator) throws NoSuchLinkException { AssetLink assetLink = findByPrimaryKey(linkId); Session session = null; try { session = openSession(); AssetLink[] array = new AssetLinkImpl[3]; array[0] = getByE1_T_PrevAndNext( session, assetLink, entryId1, type, orderByComparator, true); array[1] = assetLink; array[2] = getByE1_T_PrevAndNext( session, assetLink, entryId1, type, orderByComparator, false); return array; } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } protected AssetLink getByE1_T_PrevAndNext( Session session, AssetLink assetLink, long entryId1, int type, 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_ASSETLINK_WHERE); sb.append(_FINDER_COLUMN_E1_T_ENTRYID1_2); sb.append(_FINDER_COLUMN_E1_T_TYPE_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(AssetLinkModelImpl.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(entryId1); queryPos.add(type); if (orderByComparator != null) { for (Object orderByConditionValue : orderByComparator.getOrderByConditionValues(assetLink)) { queryPos.add(orderByConditionValue); } } List list = query.list(); if (list.size() == 2) { return list.get(1); } else { return null; } } /** * Removes all the asset links where entryId1 = ? and type = ? from the database. * * @param entryId1 the entry id1 * @param type the type */ @Override public void removeByE1_T(long entryId1, int type) { for (AssetLink assetLink : findByE1_T( entryId1, type, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null)) { remove(assetLink); } } /** * Returns the number of asset links where entryId1 = ? and type = ?. * * @param entryId1 the entry id1 * @param type the type * @return the number of matching asset links */ @Override public int countByE1_T(long entryId1, int type) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( AssetLink.class)) { FinderPath finderPath = _finderPathCountByE1_T; Object[] finderArgs = new Object[] {entryId1, type}; Long count = (Long)finderCache.getResult( finderPath, finderArgs, this); if (count == null) { StringBundler sb = new StringBundler(3); sb.append(_SQL_COUNT_ASSETLINK_WHERE); sb.append(_FINDER_COLUMN_E1_T_ENTRYID1_2); sb.append(_FINDER_COLUMN_E1_T_TYPE_2); String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(entryId1); queryPos.add(type); 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_E1_T_ENTRYID1_2 = "assetLink.entryId1 = ? AND "; private static final String _FINDER_COLUMN_E1_T_TYPE_2 = "assetLink.type = ?"; private FinderPath _finderPathWithPaginationFindByE2_T; private FinderPath _finderPathWithoutPaginationFindByE2_T; private FinderPath _finderPathCountByE2_T; /** * Returns all the asset links where entryId2 = ? and type = ?. * * @param entryId2 the entry id2 * @param type the type * @return the matching asset links */ @Override public List findByE2_T(long entryId2, int type) { return findByE2_T( entryId2, type, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null); } /** * Returns a range of all the asset links where entryId2 = ? and type = ?. * *

* 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 AssetLinkModelImpl. *

* * @param entryId2 the entry id2 * @param type the type * @param start the lower bound of the range of asset links * @param end the upper bound of the range of asset links (not inclusive) * @return the range of matching asset links */ @Override public List findByE2_T( long entryId2, int type, int start, int end) { return findByE2_T(entryId2, type, start, end, null); } /** * Returns an ordered range of all the asset links where entryId2 = ? and type = ?. * *

* 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 AssetLinkModelImpl. *

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

* 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 AssetLinkModelImpl. *

* * @param entryId2 the entry id2 * @param type the type * @param start the lower bound of the range of asset links * @param end the upper bound of the range of asset 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 asset links */ @Override public List findByE2_T( long entryId2, int type, int start, int end, OrderByComparator orderByComparator, boolean useFinderCache) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( AssetLink.class)) { FinderPath finderPath = null; Object[] finderArgs = null; if ((start == QueryUtil.ALL_POS) && (end == QueryUtil.ALL_POS) && (orderByComparator == null)) { if (useFinderCache) { finderPath = _finderPathWithoutPaginationFindByE2_T; finderArgs = new Object[] {entryId2, type}; } } else if (useFinderCache) { finderPath = _finderPathWithPaginationFindByE2_T; finderArgs = new Object[] { entryId2, type, start, end, orderByComparator }; } List list = null; if (useFinderCache) { list = (List)finderCache.getResult( finderPath, finderArgs, this); if ((list != null) && !list.isEmpty()) { for (AssetLink assetLink : list) { if ((entryId2 != assetLink.getEntryId2()) || (type != assetLink.getType())) { 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_ASSETLINK_WHERE); sb.append(_FINDER_COLUMN_E2_T_ENTRYID2_2); sb.append(_FINDER_COLUMN_E2_T_TYPE_2); if (orderByComparator != null) { appendOrderByComparator( sb, _ORDER_BY_ENTITY_ALIAS, orderByComparator); } else { sb.append(AssetLinkModelImpl.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(entryId2); queryPos.add(type); 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 asset link in the ordered set where entryId2 = ? and type = ?. * * @param entryId2 the entry id2 * @param type the type * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching asset link * @throws NoSuchLinkException if a matching asset link could not be found */ @Override public AssetLink findByE2_T_First( long entryId2, int type, OrderByComparator orderByComparator) throws NoSuchLinkException { AssetLink assetLink = fetchByE2_T_First( entryId2, type, orderByComparator); if (assetLink != null) { return assetLink; } StringBundler sb = new StringBundler(6); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("entryId2="); sb.append(entryId2); sb.append(", type="); sb.append(type); sb.append("}"); throw new NoSuchLinkException(sb.toString()); } /** * Returns the first asset link in the ordered set where entryId2 = ? and type = ?. * * @param entryId2 the entry id2 * @param type the type * @param orderByComparator the comparator to order the set by (optionally null) * @return the first matching asset link, or null if a matching asset link could not be found */ @Override public AssetLink fetchByE2_T_First( long entryId2, int type, OrderByComparator orderByComparator) { List list = findByE2_T( entryId2, type, 0, 1, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the last asset link in the ordered set where entryId2 = ? and type = ?. * * @param entryId2 the entry id2 * @param type the type * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching asset link * @throws NoSuchLinkException if a matching asset link could not be found */ @Override public AssetLink findByE2_T_Last( long entryId2, int type, OrderByComparator orderByComparator) throws NoSuchLinkException { AssetLink assetLink = fetchByE2_T_Last( entryId2, type, orderByComparator); if (assetLink != null) { return assetLink; } StringBundler sb = new StringBundler(6); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("entryId2="); sb.append(entryId2); sb.append(", type="); sb.append(type); sb.append("}"); throw new NoSuchLinkException(sb.toString()); } /** * Returns the last asset link in the ordered set where entryId2 = ? and type = ?. * * @param entryId2 the entry id2 * @param type the type * @param orderByComparator the comparator to order the set by (optionally null) * @return the last matching asset link, or null if a matching asset link could not be found */ @Override public AssetLink fetchByE2_T_Last( long entryId2, int type, OrderByComparator orderByComparator) { int count = countByE2_T(entryId2, type); if (count == 0) { return null; } List list = findByE2_T( entryId2, type, count - 1, count, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the asset links before and after the current asset link in the ordered set where entryId2 = ? and type = ?. * * @param linkId the primary key of the current asset link * @param entryId2 the entry id2 * @param type the type * @param orderByComparator the comparator to order the set by (optionally null) * @return the previous, current, and next asset link * @throws NoSuchLinkException if a asset link with the primary key could not be found */ @Override public AssetLink[] findByE2_T_PrevAndNext( long linkId, long entryId2, int type, OrderByComparator orderByComparator) throws NoSuchLinkException { AssetLink assetLink = findByPrimaryKey(linkId); Session session = null; try { session = openSession(); AssetLink[] array = new AssetLinkImpl[3]; array[0] = getByE2_T_PrevAndNext( session, assetLink, entryId2, type, orderByComparator, true); array[1] = assetLink; array[2] = getByE2_T_PrevAndNext( session, assetLink, entryId2, type, orderByComparator, false); return array; } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } protected AssetLink getByE2_T_PrevAndNext( Session session, AssetLink assetLink, long entryId2, int type, 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_ASSETLINK_WHERE); sb.append(_FINDER_COLUMN_E2_T_ENTRYID2_2); sb.append(_FINDER_COLUMN_E2_T_TYPE_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(AssetLinkModelImpl.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(entryId2); queryPos.add(type); if (orderByComparator != null) { for (Object orderByConditionValue : orderByComparator.getOrderByConditionValues(assetLink)) { queryPos.add(orderByConditionValue); } } List list = query.list(); if (list.size() == 2) { return list.get(1); } else { return null; } } /** * Removes all the asset links where entryId2 = ? and type = ? from the database. * * @param entryId2 the entry id2 * @param type the type */ @Override public void removeByE2_T(long entryId2, int type) { for (AssetLink assetLink : findByE2_T( entryId2, type, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null)) { remove(assetLink); } } /** * Returns the number of asset links where entryId2 = ? and type = ?. * * @param entryId2 the entry id2 * @param type the type * @return the number of matching asset links */ @Override public int countByE2_T(long entryId2, int type) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( AssetLink.class)) { FinderPath finderPath = _finderPathCountByE2_T; Object[] finderArgs = new Object[] {entryId2, type}; Long count = (Long)finderCache.getResult( finderPath, finderArgs, this); if (count == null) { StringBundler sb = new StringBundler(3); sb.append(_SQL_COUNT_ASSETLINK_WHERE); sb.append(_FINDER_COLUMN_E2_T_ENTRYID2_2); sb.append(_FINDER_COLUMN_E2_T_TYPE_2); String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(entryId2); queryPos.add(type); 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_E2_T_ENTRYID2_2 = "assetLink.entryId2 = ? AND "; private static final String _FINDER_COLUMN_E2_T_TYPE_2 = "assetLink.type = ?"; private FinderPath _finderPathFetchByE_E_T; /** * Returns the asset link where entryId1 = ? and entryId2 = ? and type = ? or throws a NoSuchLinkException if it could not be found. * * @param entryId1 the entry id1 * @param entryId2 the entry id2 * @param type the type * @return the matching asset link * @throws NoSuchLinkException if a matching asset link could not be found */ @Override public AssetLink findByE_E_T(long entryId1, long entryId2, int type) throws NoSuchLinkException { AssetLink assetLink = fetchByE_E_T(entryId1, entryId2, type); if (assetLink == null) { StringBundler sb = new StringBundler(8); sb.append(_NO_SUCH_ENTITY_WITH_KEY); sb.append("entryId1="); sb.append(entryId1); sb.append(", entryId2="); sb.append(entryId2); sb.append(", type="); sb.append(type); sb.append("}"); if (_log.isDebugEnabled()) { _log.debug(sb.toString()); } throw new NoSuchLinkException(sb.toString()); } return assetLink; } /** * Returns the asset link where entryId1 = ? and entryId2 = ? and type = ? or returns null if it could not be found. Uses the finder cache. * * @param entryId1 the entry id1 * @param entryId2 the entry id2 * @param type the type * @return the matching asset link, or null if a matching asset link could not be found */ @Override public AssetLink fetchByE_E_T(long entryId1, long entryId2, int type) { return fetchByE_E_T(entryId1, entryId2, type, true); } /** * Returns the asset link where entryId1 = ? and entryId2 = ? and type = ? or returns null if it could not be found, optionally using the finder cache. * * @param entryId1 the entry id1 * @param entryId2 the entry id2 * @param type the type * @param useFinderCache whether to use the finder cache * @return the matching asset link, or null if a matching asset link could not be found */ @Override public AssetLink fetchByE_E_T( long entryId1, long entryId2, int type, boolean useFinderCache) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( AssetLink.class)) { Object[] finderArgs = null; if (useFinderCache) { finderArgs = new Object[] {entryId1, entryId2, type}; } Object result = null; if (useFinderCache) { result = finderCache.getResult( _finderPathFetchByE_E_T, finderArgs, this); } if (result instanceof AssetLink) { AssetLink assetLink = (AssetLink)result; if ((entryId1 != assetLink.getEntryId1()) || (entryId2 != assetLink.getEntryId2()) || (type != assetLink.getType())) { result = null; } } if (result == null) { StringBundler sb = new StringBundler(5); sb.append(_SQL_SELECT_ASSETLINK_WHERE); sb.append(_FINDER_COLUMN_E_E_T_ENTRYID1_2); sb.append(_FINDER_COLUMN_E_E_T_ENTRYID2_2); sb.append(_FINDER_COLUMN_E_E_T_TYPE_2); String sql = sb.toString(); Session session = null; try { session = openSession(); Query query = session.createQuery(sql); QueryPos queryPos = QueryPos.getInstance(query); queryPos.add(entryId1); queryPos.add(entryId2); queryPos.add(type); List list = query.list(); if (list.isEmpty()) { if (useFinderCache) { finderCache.putResult( _finderPathFetchByE_E_T, finderArgs, list); } } else { AssetLink assetLink = list.get(0); result = assetLink; cacheResult(assetLink); } } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } if (result instanceof List) { return null; } else { return (AssetLink)result; } } } /** * Removes the asset link where entryId1 = ? and entryId2 = ? and type = ? from the database. * * @param entryId1 the entry id1 * @param entryId2 the entry id2 * @param type the type * @return the asset link that was removed */ @Override public AssetLink removeByE_E_T(long entryId1, long entryId2, int type) throws NoSuchLinkException { AssetLink assetLink = findByE_E_T(entryId1, entryId2, type); return remove(assetLink); } /** * Returns the number of asset links where entryId1 = ? and entryId2 = ? and type = ?. * * @param entryId1 the entry id1 * @param entryId2 the entry id2 * @param type the type * @return the number of matching asset links */ @Override public int countByE_E_T(long entryId1, long entryId2, int type) { AssetLink assetLink = fetchByE_E_T(entryId1, entryId2, type); if (assetLink == null) { return 0; } return 1; } private static final String _FINDER_COLUMN_E_E_T_ENTRYID1_2 = "assetLink.entryId1 = ? AND "; private static final String _FINDER_COLUMN_E_E_T_ENTRYID2_2 = "assetLink.entryId2 = ? AND "; private static final String _FINDER_COLUMN_E_E_T_TYPE_2 = "assetLink.type = ?"; public AssetLinkPersistenceImpl() { Map dbColumnNames = new HashMap(); dbColumnNames.put("type", "type_"); setDBColumnNames(dbColumnNames); setModelClass(AssetLink.class); setModelImplClass(AssetLinkImpl.class); setModelPKClass(long.class); setTable(AssetLinkTable.INSTANCE); } /** * Caches the asset link in the entity cache if it is enabled. * * @param assetLink the asset link */ @Override public void cacheResult(AssetLink assetLink) { try (SafeCloseable safeCloseable = CTCollectionThreadLocal.setCTCollectionIdWithSafeCloseable( assetLink.getCtCollectionId())) { entityCache.putResult( AssetLinkImpl.class, assetLink.getPrimaryKey(), assetLink); finderCache.putResult( _finderPathFetchByE_E_T, new Object[] { assetLink.getEntryId1(), assetLink.getEntryId2(), assetLink.getType() }, assetLink); } } private int _valueObjectFinderCacheListThreshold; /** * Caches the asset links in the entity cache if it is enabled. * * @param assetLinks the asset links */ @Override public void cacheResult(List assetLinks) { if ((_valueObjectFinderCacheListThreshold == 0) || ((_valueObjectFinderCacheListThreshold > 0) && (assetLinks.size() > _valueObjectFinderCacheListThreshold))) { return; } for (AssetLink assetLink : assetLinks) { try (SafeCloseable safeCloseable = CTCollectionThreadLocal.setCTCollectionIdWithSafeCloseable( assetLink.getCtCollectionId())) { if (entityCache.getResult( AssetLinkImpl.class, assetLink.getPrimaryKey()) == null) { cacheResult(assetLink); } } } } /** * Clears the cache for all asset links. * *

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

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

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

*/ @Override public void clearCache(AssetLink assetLink) { entityCache.removeResult(AssetLinkImpl.class, assetLink); } @Override public void clearCache(List assetLinks) { for (AssetLink assetLink : assetLinks) { entityCache.removeResult(AssetLinkImpl.class, assetLink); } } @Override public void clearCache(Set primaryKeys) { finderCache.clearCache(AssetLinkImpl.class); for (Serializable primaryKey : primaryKeys) { entityCache.removeResult(AssetLinkImpl.class, primaryKey); } } protected void cacheUniqueFindersCache( AssetLinkModelImpl assetLinkModelImpl) { try (SafeCloseable safeCloseable = CTCollectionThreadLocal.setCTCollectionIdWithSafeCloseable( assetLinkModelImpl.getCtCollectionId())) { Object[] args = new Object[] { assetLinkModelImpl.getEntryId1(), assetLinkModelImpl.getEntryId2(), assetLinkModelImpl.getType() }; finderCache.putResult( _finderPathFetchByE_E_T, args, assetLinkModelImpl); } } /** * Creates a new asset link with the primary key. Does not add the asset link to the database. * * @param linkId the primary key for the new asset link * @return the new asset link */ @Override public AssetLink create(long linkId) { AssetLink assetLink = new AssetLinkImpl(); assetLink.setNew(true); assetLink.setPrimaryKey(linkId); assetLink.setCompanyId(CompanyThreadLocal.getCompanyId()); return assetLink; } /** * Removes the asset link with the primary key from the database. Also notifies the appropriate model listeners. * * @param linkId the primary key of the asset link * @return the asset link that was removed * @throws NoSuchLinkException if a asset link with the primary key could not be found */ @Override public AssetLink remove(long linkId) throws NoSuchLinkException { return remove((Serializable)linkId); } /** * Removes the asset link with the primary key from the database. Also notifies the appropriate model listeners. * * @param primaryKey the primary key of the asset link * @return the asset link that was removed * @throws NoSuchLinkException if a asset link with the primary key could not be found */ @Override public AssetLink remove(Serializable primaryKey) throws NoSuchLinkException { Session session = null; try { session = openSession(); AssetLink assetLink = (AssetLink)session.get( AssetLinkImpl.class, primaryKey); if (assetLink == null) { if (_log.isDebugEnabled()) { _log.debug(_NO_SUCH_ENTITY_WITH_PRIMARY_KEY + primaryKey); } throw new NoSuchLinkException( _NO_SUCH_ENTITY_WITH_PRIMARY_KEY + primaryKey); } return remove(assetLink); } catch (NoSuchLinkException noSuchEntityException) { throw noSuchEntityException; } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } } @Override protected AssetLink removeImpl(AssetLink assetLink) { Session session = null; try { session = openSession(); if (!session.contains(assetLink)) { assetLink = (AssetLink)session.get( AssetLinkImpl.class, assetLink.getPrimaryKeyObj()); } if ((assetLink != null) && ctPersistenceHelper.isRemove(assetLink)) { session.delete(assetLink); } } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } if (assetLink != null) { clearCache(assetLink); } return assetLink; } @Override public AssetLink updateImpl(AssetLink assetLink) { boolean isNew = assetLink.isNew(); if (!(assetLink instanceof AssetLinkModelImpl)) { InvocationHandler invocationHandler = null; if (ProxyUtil.isProxyClass(assetLink.getClass())) { invocationHandler = ProxyUtil.getInvocationHandler(assetLink); throw new IllegalArgumentException( "Implement ModelWrapper in assetLink proxy " + invocationHandler.getClass()); } throw new IllegalArgumentException( "Implement ModelWrapper in custom AssetLink implementation " + assetLink.getClass()); } AssetLinkModelImpl assetLinkModelImpl = (AssetLinkModelImpl)assetLink; if (isNew && (assetLink.getCreateDate() == null)) { ServiceContext serviceContext = ServiceContextThreadLocal.getServiceContext(); Date date = new Date(); if (serviceContext == null) { assetLink.setCreateDate(date); } else { assetLink.setCreateDate(serviceContext.getCreateDate(date)); } } Session session = null; try { session = openSession(); if (ctPersistenceHelper.isInsert(assetLink)) { if (!isNew) { session.evict( AssetLinkImpl.class, assetLink.getPrimaryKeyObj()); } session.save(assetLink); } else { assetLink = (AssetLink)session.merge(assetLink); } } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } entityCache.putResult( AssetLinkImpl.class, assetLinkModelImpl, false, true); cacheUniqueFindersCache(assetLinkModelImpl); if (isNew) { assetLink.setNew(false); } assetLink.resetOriginalValues(); return assetLink; } /** * Returns the asset 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 asset link * @return the asset link * @throws NoSuchLinkException if a asset link with the primary key could not be found */ @Override public AssetLink findByPrimaryKey(Serializable primaryKey) throws NoSuchLinkException { AssetLink assetLink = fetchByPrimaryKey(primaryKey); if (assetLink == null) { if (_log.isDebugEnabled()) { _log.debug(_NO_SUCH_ENTITY_WITH_PRIMARY_KEY + primaryKey); } throw new NoSuchLinkException( _NO_SUCH_ENTITY_WITH_PRIMARY_KEY + primaryKey); } return assetLink; } /** * Returns the asset link with the primary key or throws a NoSuchLinkException if it could not be found. * * @param linkId the primary key of the asset link * @return the asset link * @throws NoSuchLinkException if a asset link with the primary key could not be found */ @Override public AssetLink findByPrimaryKey(long linkId) throws NoSuchLinkException { return findByPrimaryKey((Serializable)linkId); } /** * Returns the asset link with the primary key or returns null if it could not be found. * * @param primaryKey the primary key of the asset link * @return the asset link, or null if a asset link with the primary key could not be found */ @Override public AssetLink fetchByPrimaryKey(Serializable primaryKey) { if (ctPersistenceHelper.isProductionMode(AssetLink.class, primaryKey)) { try (SafeCloseable safeCloseable = CTCollectionThreadLocal. setProductionModeWithSafeCloseable()) { return super.fetchByPrimaryKey(primaryKey); } } AssetLink assetLink = (AssetLink)entityCache.getResult( AssetLinkImpl.class, primaryKey); if (assetLink != null) { return assetLink; } Session session = null; try { session = openSession(); assetLink = (AssetLink)session.get(AssetLinkImpl.class, primaryKey); if (assetLink != null) { cacheResult(assetLink); } } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } return assetLink; } /** * Returns the asset link with the primary key or returns null if it could not be found. * * @param linkId the primary key of the asset link * @return the asset link, or null if a asset link with the primary key could not be found */ @Override public AssetLink fetchByPrimaryKey(long linkId) { return fetchByPrimaryKey((Serializable)linkId); } @Override public Map fetchByPrimaryKeys( Set primaryKeys) { if (ctPersistenceHelper.isProductionMode(AssetLink.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(); AssetLink assetLink = fetchByPrimaryKey(primaryKey); if (assetLink != null) { map.put(primaryKey, assetLink); } return map; } Set uncachedPrimaryKeys = null; for (Serializable primaryKey : primaryKeys) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( AssetLink.class, primaryKey)) { AssetLink assetLink = (AssetLink)entityCache.getResult( AssetLinkImpl.class, primaryKey); if (assetLink == null) { if (uncachedPrimaryKeys == null) { uncachedPrimaryKeys = new HashSet<>(); } uncachedPrimaryKeys.add(primaryKey); } else { map.put(primaryKey, assetLink); } } } 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 (AssetLink assetLink : (List)query.list()) { map.put(assetLink.getPrimaryKeyObj(), assetLink); cacheResult(assetLink); } } catch (Exception exception) { throw processException(exception); } finally { closeSession(session); } return map; } /** * Returns all the asset links. * * @return the asset links */ @Override public List findAll() { return findAll(QueryUtil.ALL_POS, QueryUtil.ALL_POS, null); } /** * Returns a range of all the asset 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 AssetLinkModelImpl. *

* * @param start the lower bound of the range of asset links * @param end the upper bound of the range of asset links (not inclusive) * @return the range of asset links */ @Override public List findAll(int start, int end) { return findAll(start, end, null); } /** * Returns an ordered range of all the asset 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 AssetLinkModelImpl. *

* * @param start the lower bound of the range of asset links * @param end the upper bound of the range of asset links (not inclusive) * @param orderByComparator the comparator to order the results by (optionally null) * @return the ordered range of asset links */ @Override public List findAll( int start, int end, OrderByComparator orderByComparator) { return findAll(start, end, orderByComparator, true); } /** * Returns an ordered range of all the asset 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 AssetLinkModelImpl. *

* * @param start the lower bound of the range of asset links * @param end the upper bound of the range of asset 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 asset links */ @Override public List findAll( int start, int end, OrderByComparator orderByComparator, boolean useFinderCache) { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( AssetLink.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_ASSETLINK); appendOrderByComparator( sb, _ORDER_BY_ENTITY_ALIAS, orderByComparator); sql = sb.toString(); } else { sql = _SQL_SELECT_ASSETLINK; sql = sql.concat(AssetLinkModelImpl.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 asset links from the database. * */ @Override public void removeAll() { for (AssetLink assetLink : findAll()) { remove(assetLink); } } /** * Returns the number of asset links. * * @return the number of asset links */ @Override public int countAll() { try (SafeCloseable safeCloseable = ctPersistenceHelper.setCTCollectionIdWithSafeCloseable( AssetLink.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_ASSETLINK); 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 "linkId"; } @Override protected String getSelectSQL() { return _SQL_SELECT_ASSETLINK; } @Override public Set getCTColumnNames( CTColumnResolutionType ctColumnResolutionType) { return _ctColumnNamesMap.getOrDefault( ctColumnResolutionType, Collections.emptySet()); } @Override public List getMappingTableNames() { return _mappingTableNames; } @Override public Map getTableColumnsMap() { return AssetLinkModelImpl.TABLE_COLUMNS_MAP; } @Override public String getTableName() { return "AssetLink"; } @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 ctMergeColumnNames = new HashSet(); Set ctStrictColumnNames = new HashSet(); ctControlColumnNames.add("mvccVersion"); ctControlColumnNames.add("ctCollectionId"); ctStrictColumnNames.add("companyId"); ctStrictColumnNames.add("userId"); ctStrictColumnNames.add("userName"); ctStrictColumnNames.add("createDate"); ctMergeColumnNames.add("entryId1"); ctMergeColumnNames.add("entryId2"); ctMergeColumnNames.add("type_"); ctMergeColumnNames.add("weight"); _ctColumnNamesMap.put( CTColumnResolutionType.CONTROL, ctControlColumnNames); _ctColumnNamesMap.put(CTColumnResolutionType.MERGE, ctMergeColumnNames); _ctColumnNamesMap.put( CTColumnResolutionType.PK, Collections.singleton("linkId")); _ctColumnNamesMap.put( CTColumnResolutionType.STRICT, ctStrictColumnNames); _uniqueIndexColumnNames.add( new String[] {"entryId1", "entryId2", "type_"}); } /** * Initializes the asset 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); _finderPathWithPaginationFindByEntryId1 = new FinderPath( FINDER_CLASS_NAME_LIST_WITH_PAGINATION, "findByEntryId1", new String[] { Long.class.getName(), Integer.class.getName(), Integer.class.getName(), OrderByComparator.class.getName() }, new String[] {"entryId1"}, true); _finderPathWithoutPaginationFindByEntryId1 = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "findByEntryId1", new String[] {Long.class.getName()}, new String[] {"entryId1"}, true); _finderPathCountByEntryId1 = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "countByEntryId1", new String[] {Long.class.getName()}, new String[] {"entryId1"}, false); _finderPathWithPaginationFindByEntryId2 = new FinderPath( FINDER_CLASS_NAME_LIST_WITH_PAGINATION, "findByEntryId2", new String[] { Long.class.getName(), Integer.class.getName(), Integer.class.getName(), OrderByComparator.class.getName() }, new String[] {"entryId2"}, true); _finderPathWithoutPaginationFindByEntryId2 = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "findByEntryId2", new String[] {Long.class.getName()}, new String[] {"entryId2"}, true); _finderPathCountByEntryId2 = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "countByEntryId2", new String[] {Long.class.getName()}, new String[] {"entryId2"}, false); _finderPathWithPaginationFindByE_E = new FinderPath( FINDER_CLASS_NAME_LIST_WITH_PAGINATION, "findByE_E", new String[] { Long.class.getName(), Long.class.getName(), Integer.class.getName(), Integer.class.getName(), OrderByComparator.class.getName() }, new String[] {"entryId1", "entryId2"}, true); _finderPathWithoutPaginationFindByE_E = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "findByE_E", new String[] {Long.class.getName(), Long.class.getName()}, new String[] {"entryId1", "entryId2"}, true); _finderPathCountByE_E = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "countByE_E", new String[] {Long.class.getName(), Long.class.getName()}, new String[] {"entryId1", "entryId2"}, false); _finderPathWithPaginationFindByE1_T = new FinderPath( FINDER_CLASS_NAME_LIST_WITH_PAGINATION, "findByE1_T", new String[] { Long.class.getName(), Integer.class.getName(), Integer.class.getName(), Integer.class.getName(), OrderByComparator.class.getName() }, new String[] {"entryId1", "type_"}, true); _finderPathWithoutPaginationFindByE1_T = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "findByE1_T", new String[] {Long.class.getName(), Integer.class.getName()}, new String[] {"entryId1", "type_"}, true); _finderPathCountByE1_T = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "countByE1_T", new String[] {Long.class.getName(), Integer.class.getName()}, new String[] {"entryId1", "type_"}, false); _finderPathWithPaginationFindByE2_T = new FinderPath( FINDER_CLASS_NAME_LIST_WITH_PAGINATION, "findByE2_T", new String[] { Long.class.getName(), Integer.class.getName(), Integer.class.getName(), Integer.class.getName(), OrderByComparator.class.getName() }, new String[] {"entryId2", "type_"}, true); _finderPathWithoutPaginationFindByE2_T = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "findByE2_T", new String[] {Long.class.getName(), Integer.class.getName()}, new String[] {"entryId2", "type_"}, true); _finderPathCountByE2_T = new FinderPath( FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "countByE2_T", new String[] {Long.class.getName(), Integer.class.getName()}, new String[] {"entryId2", "type_"}, false); _finderPathFetchByE_E_T = new FinderPath( FINDER_CLASS_NAME_ENTITY, "fetchByE_E_T", new String[] { Long.class.getName(), Long.class.getName(), Integer.class.getName() }, new String[] {"entryId1", "entryId2", "type_"}, true); AssetLinkUtil.setPersistence(this); } @Deactivate public void deactivate() { AssetLinkUtil.setPersistence(null); entityCache.removeCache(AssetLinkImpl.class.getName()); } @Override @Reference( target = AssetPersistenceConstants.SERVICE_CONFIGURATION_FILTER, unbind = "-" ) public void setConfiguration(Configuration configuration) { } @Override @Reference( target = AssetPersistenceConstants.ORIGIN_BUNDLE_SYMBOLIC_NAME_FILTER, unbind = "-" ) public void setDataSource(DataSource dataSource) { super.setDataSource(dataSource); } @Override @Reference( target = AssetPersistenceConstants.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_ASSETLINK = "SELECT assetLink FROM AssetLink assetLink"; private static final String _SQL_SELECT_ASSETLINK_WHERE = "SELECT assetLink FROM AssetLink assetLink WHERE "; private static final String _SQL_COUNT_ASSETLINK = "SELECT COUNT(assetLink) FROM AssetLink assetLink"; private static final String _SQL_COUNT_ASSETLINK_WHERE = "SELECT COUNT(assetLink) FROM AssetLink assetLink WHERE "; private static final String _ORDER_BY_ENTITY_ALIAS = "assetLink."; private static final String _NO_SUCH_ENTITY_WITH_PRIMARY_KEY = "No AssetLink exists with the primary key "; private static final String _NO_SUCH_ENTITY_WITH_KEY = "No AssetLink exists with the key {"; private static final Log _log = LogFactoryUtil.getLog( AssetLinkPersistenceImpl.class); private static final Set _badColumnNames = SetUtil.fromArray( new String[] {"type"}); @Override protected FinderCache getFinderCache() { return finderCache; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy