001
014
015 package com.liferay.portlet.dynamicdatamapping.service.persistence;
016
017 import com.liferay.portal.kernel.cache.CacheRegistryUtil;
018 import com.liferay.portal.kernel.dao.orm.EntityCacheUtil;
019 import com.liferay.portal.kernel.dao.orm.FinderCacheUtil;
020 import com.liferay.portal.kernel.dao.orm.FinderPath;
021 import com.liferay.portal.kernel.dao.orm.Query;
022 import com.liferay.portal.kernel.dao.orm.QueryPos;
023 import com.liferay.portal.kernel.dao.orm.QueryUtil;
024 import com.liferay.portal.kernel.dao.orm.Session;
025 import com.liferay.portal.kernel.exception.SystemException;
026 import com.liferay.portal.kernel.log.Log;
027 import com.liferay.portal.kernel.log.LogFactoryUtil;
028 import com.liferay.portal.kernel.util.GetterUtil;
029 import com.liferay.portal.kernel.util.InstanceFactory;
030 import com.liferay.portal.kernel.util.OrderByComparator;
031 import com.liferay.portal.kernel.util.SetUtil;
032 import com.liferay.portal.kernel.util.StringBundler;
033 import com.liferay.portal.kernel.util.StringPool;
034 import com.liferay.portal.kernel.util.StringUtil;
035 import com.liferay.portal.kernel.util.UnmodifiableList;
036 import com.liferay.portal.kernel.util.Validator;
037 import com.liferay.portal.kernel.uuid.PortalUUIDUtil;
038 import com.liferay.portal.model.CacheModel;
039 import com.liferay.portal.model.ModelListener;
040 import com.liferay.portal.service.persistence.impl.BasePersistenceImpl;
041
042 import com.liferay.portlet.dynamicdatamapping.NoSuchContentException;
043 import com.liferay.portlet.dynamicdatamapping.model.DDMContent;
044 import com.liferay.portlet.dynamicdatamapping.model.impl.DDMContentImpl;
045 import com.liferay.portlet.dynamicdatamapping.model.impl.DDMContentModelImpl;
046
047 import java.io.Serializable;
048
049 import java.util.ArrayList;
050 import java.util.Collections;
051 import java.util.List;
052 import java.util.Set;
053
054
066 public class DDMContentPersistenceImpl extends BasePersistenceImpl<DDMContent>
067 implements DDMContentPersistence {
068
073 public static final String FINDER_CLASS_NAME_ENTITY = DDMContentImpl.class.getName();
074 public static final String FINDER_CLASS_NAME_LIST_WITH_PAGINATION = FINDER_CLASS_NAME_ENTITY +
075 ".List1";
076 public static final String FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION = FINDER_CLASS_NAME_ENTITY +
077 ".List2";
078 public static final FinderPath FINDER_PATH_WITH_PAGINATION_FIND_ALL = new FinderPath(DDMContentModelImpl.ENTITY_CACHE_ENABLED,
079 DDMContentModelImpl.FINDER_CACHE_ENABLED, DDMContentImpl.class,
080 FINDER_CLASS_NAME_LIST_WITH_PAGINATION, "findAll", new String[0]);
081 public static final FinderPath FINDER_PATH_WITHOUT_PAGINATION_FIND_ALL = new FinderPath(DDMContentModelImpl.ENTITY_CACHE_ENABLED,
082 DDMContentModelImpl.FINDER_CACHE_ENABLED, DDMContentImpl.class,
083 FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "findAll", new String[0]);
084 public static final FinderPath FINDER_PATH_COUNT_ALL = new FinderPath(DDMContentModelImpl.ENTITY_CACHE_ENABLED,
085 DDMContentModelImpl.FINDER_CACHE_ENABLED, Long.class,
086 FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "countAll", new String[0]);
087 public static final FinderPath FINDER_PATH_WITH_PAGINATION_FIND_BY_UUID = new FinderPath(DDMContentModelImpl.ENTITY_CACHE_ENABLED,
088 DDMContentModelImpl.FINDER_CACHE_ENABLED, DDMContentImpl.class,
089 FINDER_CLASS_NAME_LIST_WITH_PAGINATION, "findByUuid",
090 new String[] {
091 String.class.getName(),
092
093 Integer.class.getName(), Integer.class.getName(),
094 OrderByComparator.class.getName()
095 });
096 public static final FinderPath FINDER_PATH_WITHOUT_PAGINATION_FIND_BY_UUID = new FinderPath(DDMContentModelImpl.ENTITY_CACHE_ENABLED,
097 DDMContentModelImpl.FINDER_CACHE_ENABLED, DDMContentImpl.class,
098 FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "findByUuid",
099 new String[] { String.class.getName() },
100 DDMContentModelImpl.UUID_COLUMN_BITMASK);
101 public static final FinderPath FINDER_PATH_COUNT_BY_UUID = new FinderPath(DDMContentModelImpl.ENTITY_CACHE_ENABLED,
102 DDMContentModelImpl.FINDER_CACHE_ENABLED, Long.class,
103 FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "countByUuid",
104 new String[] { String.class.getName() });
105
106
113 @Override
114 public List<DDMContent> findByUuid(String uuid) throws SystemException {
115 return findByUuid(uuid, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null);
116 }
117
118
131 @Override
132 public List<DDMContent> findByUuid(String uuid, int start, int end)
133 throws SystemException {
134 return findByUuid(uuid, start, end, null);
135 }
136
137
151 @Override
152 public List<DDMContent> findByUuid(String uuid, int start, int end,
153 OrderByComparator orderByComparator) throws SystemException {
154 boolean pagination = true;
155 FinderPath finderPath = null;
156 Object[] finderArgs = null;
157
158 if ((start == QueryUtil.ALL_POS) && (end == QueryUtil.ALL_POS) &&
159 (orderByComparator == null)) {
160 pagination = false;
161 finderPath = FINDER_PATH_WITHOUT_PAGINATION_FIND_BY_UUID;
162 finderArgs = new Object[] { uuid };
163 }
164 else {
165 finderPath = FINDER_PATH_WITH_PAGINATION_FIND_BY_UUID;
166 finderArgs = new Object[] { uuid, start, end, orderByComparator };
167 }
168
169 List<DDMContent> list = (List<DDMContent>)FinderCacheUtil.getResult(finderPath,
170 finderArgs, this);
171
172 if ((list != null) && !list.isEmpty()) {
173 for (DDMContent ddmContent : list) {
174 if (!Validator.equals(uuid, ddmContent.getUuid())) {
175 list = null;
176
177 break;
178 }
179 }
180 }
181
182 if (list == null) {
183 StringBundler query = null;
184
185 if (orderByComparator != null) {
186 query = new StringBundler(3 +
187 (orderByComparator.getOrderByFields().length * 3));
188 }
189 else {
190 query = new StringBundler(3);
191 }
192
193 query.append(_SQL_SELECT_DDMCONTENT_WHERE);
194
195 boolean bindUuid = false;
196
197 if (uuid == null) {
198 query.append(_FINDER_COLUMN_UUID_UUID_1);
199 }
200 else if (uuid.equals(StringPool.BLANK)) {
201 query.append(_FINDER_COLUMN_UUID_UUID_3);
202 }
203 else {
204 bindUuid = true;
205
206 query.append(_FINDER_COLUMN_UUID_UUID_2);
207 }
208
209 if (orderByComparator != null) {
210 appendOrderByComparator(query, _ORDER_BY_ENTITY_ALIAS,
211 orderByComparator);
212 }
213 else
214 if (pagination) {
215 query.append(DDMContentModelImpl.ORDER_BY_JPQL);
216 }
217
218 String sql = query.toString();
219
220 Session session = null;
221
222 try {
223 session = openSession();
224
225 Query q = session.createQuery(sql);
226
227 QueryPos qPos = QueryPos.getInstance(q);
228
229 if (bindUuid) {
230 qPos.add(uuid);
231 }
232
233 if (!pagination) {
234 list = (List<DDMContent>)QueryUtil.list(q, getDialect(),
235 start, end, false);
236
237 Collections.sort(list);
238
239 list = new UnmodifiableList<DDMContent>(list);
240 }
241 else {
242 list = (List<DDMContent>)QueryUtil.list(q, getDialect(),
243 start, end);
244 }
245
246 cacheResult(list);
247
248 FinderCacheUtil.putResult(finderPath, finderArgs, list);
249 }
250 catch (Exception e) {
251 FinderCacheUtil.removeResult(finderPath, finderArgs);
252
253 throw processException(e);
254 }
255 finally {
256 closeSession(session);
257 }
258 }
259
260 return list;
261 }
262
263
272 @Override
273 public DDMContent findByUuid_First(String uuid,
274 OrderByComparator orderByComparator)
275 throws NoSuchContentException, SystemException {
276 DDMContent ddmContent = fetchByUuid_First(uuid, orderByComparator);
277
278 if (ddmContent != null) {
279 return ddmContent;
280 }
281
282 StringBundler msg = new StringBundler(4);
283
284 msg.append(_NO_SUCH_ENTITY_WITH_KEY);
285
286 msg.append("uuid=");
287 msg.append(uuid);
288
289 msg.append(StringPool.CLOSE_CURLY_BRACE);
290
291 throw new NoSuchContentException(msg.toString());
292 }
293
294
302 @Override
303 public DDMContent fetchByUuid_First(String uuid,
304 OrderByComparator orderByComparator) throws SystemException {
305 List<DDMContent> list = findByUuid(uuid, 0, 1, orderByComparator);
306
307 if (!list.isEmpty()) {
308 return list.get(0);
309 }
310
311 return null;
312 }
313
314
323 @Override
324 public DDMContent findByUuid_Last(String uuid,
325 OrderByComparator orderByComparator)
326 throws NoSuchContentException, SystemException {
327 DDMContent ddmContent = fetchByUuid_Last(uuid, orderByComparator);
328
329 if (ddmContent != null) {
330 return ddmContent;
331 }
332
333 StringBundler msg = new StringBundler(4);
334
335 msg.append(_NO_SUCH_ENTITY_WITH_KEY);
336
337 msg.append("uuid=");
338 msg.append(uuid);
339
340 msg.append(StringPool.CLOSE_CURLY_BRACE);
341
342 throw new NoSuchContentException(msg.toString());
343 }
344
345
353 @Override
354 public DDMContent fetchByUuid_Last(String uuid,
355 OrderByComparator orderByComparator) throws SystemException {
356 int count = countByUuid(uuid);
357
358 if (count == 0) {
359 return null;
360 }
361
362 List<DDMContent> list = findByUuid(uuid, count - 1, count,
363 orderByComparator);
364
365 if (!list.isEmpty()) {
366 return list.get(0);
367 }
368
369 return null;
370 }
371
372
382 @Override
383 public DDMContent[] findByUuid_PrevAndNext(long contentId, String uuid,
384 OrderByComparator orderByComparator)
385 throws NoSuchContentException, SystemException {
386 DDMContent ddmContent = findByPrimaryKey(contentId);
387
388 Session session = null;
389
390 try {
391 session = openSession();
392
393 DDMContent[] array = new DDMContentImpl[3];
394
395 array[0] = getByUuid_PrevAndNext(session, ddmContent, uuid,
396 orderByComparator, true);
397
398 array[1] = ddmContent;
399
400 array[2] = getByUuid_PrevAndNext(session, ddmContent, uuid,
401 orderByComparator, false);
402
403 return array;
404 }
405 catch (Exception e) {
406 throw processException(e);
407 }
408 finally {
409 closeSession(session);
410 }
411 }
412
413 protected DDMContent getByUuid_PrevAndNext(Session session,
414 DDMContent ddmContent, String uuid,
415 OrderByComparator orderByComparator, boolean previous) {
416 StringBundler query = null;
417
418 if (orderByComparator != null) {
419 query = new StringBundler(6 +
420 (orderByComparator.getOrderByFields().length * 6));
421 }
422 else {
423 query = new StringBundler(3);
424 }
425
426 query.append(_SQL_SELECT_DDMCONTENT_WHERE);
427
428 boolean bindUuid = false;
429
430 if (uuid == null) {
431 query.append(_FINDER_COLUMN_UUID_UUID_1);
432 }
433 else if (uuid.equals(StringPool.BLANK)) {
434 query.append(_FINDER_COLUMN_UUID_UUID_3);
435 }
436 else {
437 bindUuid = true;
438
439 query.append(_FINDER_COLUMN_UUID_UUID_2);
440 }
441
442 if (orderByComparator != null) {
443 String[] orderByConditionFields = orderByComparator.getOrderByConditionFields();
444
445 if (orderByConditionFields.length > 0) {
446 query.append(WHERE_AND);
447 }
448
449 for (int i = 0; i < orderByConditionFields.length; i++) {
450 query.append(_ORDER_BY_ENTITY_ALIAS);
451 query.append(orderByConditionFields[i]);
452
453 if ((i + 1) < orderByConditionFields.length) {
454 if (orderByComparator.isAscending() ^ previous) {
455 query.append(WHERE_GREATER_THAN_HAS_NEXT);
456 }
457 else {
458 query.append(WHERE_LESSER_THAN_HAS_NEXT);
459 }
460 }
461 else {
462 if (orderByComparator.isAscending() ^ previous) {
463 query.append(WHERE_GREATER_THAN);
464 }
465 else {
466 query.append(WHERE_LESSER_THAN);
467 }
468 }
469 }
470
471 query.append(ORDER_BY_CLAUSE);
472
473 String[] orderByFields = orderByComparator.getOrderByFields();
474
475 for (int i = 0; i < orderByFields.length; i++) {
476 query.append(_ORDER_BY_ENTITY_ALIAS);
477 query.append(orderByFields[i]);
478
479 if ((i + 1) < orderByFields.length) {
480 if (orderByComparator.isAscending() ^ previous) {
481 query.append(ORDER_BY_ASC_HAS_NEXT);
482 }
483 else {
484 query.append(ORDER_BY_DESC_HAS_NEXT);
485 }
486 }
487 else {
488 if (orderByComparator.isAscending() ^ previous) {
489 query.append(ORDER_BY_ASC);
490 }
491 else {
492 query.append(ORDER_BY_DESC);
493 }
494 }
495 }
496 }
497 else {
498 query.append(DDMContentModelImpl.ORDER_BY_JPQL);
499 }
500
501 String sql = query.toString();
502
503 Query q = session.createQuery(sql);
504
505 q.setFirstResult(0);
506 q.setMaxResults(2);
507
508 QueryPos qPos = QueryPos.getInstance(q);
509
510 if (bindUuid) {
511 qPos.add(uuid);
512 }
513
514 if (orderByComparator != null) {
515 Object[] values = orderByComparator.getOrderByConditionValues(ddmContent);
516
517 for (Object value : values) {
518 qPos.add(value);
519 }
520 }
521
522 List<DDMContent> list = q.list();
523
524 if (list.size() == 2) {
525 return list.get(1);
526 }
527 else {
528 return null;
529 }
530 }
531
532
538 @Override
539 public void removeByUuid(String uuid) throws SystemException {
540 for (DDMContent ddmContent : findByUuid(uuid, QueryUtil.ALL_POS,
541 QueryUtil.ALL_POS, null)) {
542 remove(ddmContent);
543 }
544 }
545
546
553 @Override
554 public int countByUuid(String uuid) throws SystemException {
555 FinderPath finderPath = FINDER_PATH_COUNT_BY_UUID;
556
557 Object[] finderArgs = new Object[] { uuid };
558
559 Long count = (Long)FinderCacheUtil.getResult(finderPath, finderArgs,
560 this);
561
562 if (count == null) {
563 StringBundler query = new StringBundler(2);
564
565 query.append(_SQL_COUNT_DDMCONTENT_WHERE);
566
567 boolean bindUuid = false;
568
569 if (uuid == null) {
570 query.append(_FINDER_COLUMN_UUID_UUID_1);
571 }
572 else if (uuid.equals(StringPool.BLANK)) {
573 query.append(_FINDER_COLUMN_UUID_UUID_3);
574 }
575 else {
576 bindUuid = true;
577
578 query.append(_FINDER_COLUMN_UUID_UUID_2);
579 }
580
581 String sql = query.toString();
582
583 Session session = null;
584
585 try {
586 session = openSession();
587
588 Query q = session.createQuery(sql);
589
590 QueryPos qPos = QueryPos.getInstance(q);
591
592 if (bindUuid) {
593 qPos.add(uuid);
594 }
595
596 count = (Long)q.uniqueResult();
597
598 FinderCacheUtil.putResult(finderPath, finderArgs, count);
599 }
600 catch (Exception e) {
601 FinderCacheUtil.removeResult(finderPath, finderArgs);
602
603 throw processException(e);
604 }
605 finally {
606 closeSession(session);
607 }
608 }
609
610 return count.intValue();
611 }
612
613 private static final String _FINDER_COLUMN_UUID_UUID_1 = "ddmContent.uuid IS NULL";
614 private static final String _FINDER_COLUMN_UUID_UUID_2 = "ddmContent.uuid = ?";
615 private static final String _FINDER_COLUMN_UUID_UUID_3 = "(ddmContent.uuid IS NULL OR ddmContent.uuid = '')";
616 public static final FinderPath FINDER_PATH_FETCH_BY_UUID_G = new FinderPath(DDMContentModelImpl.ENTITY_CACHE_ENABLED,
617 DDMContentModelImpl.FINDER_CACHE_ENABLED, DDMContentImpl.class,
618 FINDER_CLASS_NAME_ENTITY, "fetchByUUID_G",
619 new String[] { String.class.getName(), Long.class.getName() },
620 DDMContentModelImpl.UUID_COLUMN_BITMASK |
621 DDMContentModelImpl.GROUPID_COLUMN_BITMASK);
622 public static final FinderPath FINDER_PATH_COUNT_BY_UUID_G = new FinderPath(DDMContentModelImpl.ENTITY_CACHE_ENABLED,
623 DDMContentModelImpl.FINDER_CACHE_ENABLED, Long.class,
624 FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "countByUUID_G",
625 new String[] { String.class.getName(), Long.class.getName() });
626
627
636 @Override
637 public DDMContent findByUUID_G(String uuid, long groupId)
638 throws NoSuchContentException, SystemException {
639 DDMContent ddmContent = fetchByUUID_G(uuid, groupId);
640
641 if (ddmContent == null) {
642 StringBundler msg = new StringBundler(6);
643
644 msg.append(_NO_SUCH_ENTITY_WITH_KEY);
645
646 msg.append("uuid=");
647 msg.append(uuid);
648
649 msg.append(", groupId=");
650 msg.append(groupId);
651
652 msg.append(StringPool.CLOSE_CURLY_BRACE);
653
654 if (_log.isWarnEnabled()) {
655 _log.warn(msg.toString());
656 }
657
658 throw new NoSuchContentException(msg.toString());
659 }
660
661 return ddmContent;
662 }
663
664
672 @Override
673 public DDMContent fetchByUUID_G(String uuid, long groupId)
674 throws SystemException {
675 return fetchByUUID_G(uuid, groupId, true);
676 }
677
678
687 @Override
688 public DDMContent fetchByUUID_G(String uuid, long groupId,
689 boolean retrieveFromCache) throws SystemException {
690 Object[] finderArgs = new Object[] { uuid, groupId };
691
692 Object result = null;
693
694 if (retrieveFromCache) {
695 result = FinderCacheUtil.getResult(FINDER_PATH_FETCH_BY_UUID_G,
696 finderArgs, this);
697 }
698
699 if (result instanceof DDMContent) {
700 DDMContent ddmContent = (DDMContent)result;
701
702 if (!Validator.equals(uuid, ddmContent.getUuid()) ||
703 (groupId != ddmContent.getGroupId())) {
704 result = null;
705 }
706 }
707
708 if (result == null) {
709 StringBundler query = new StringBundler(4);
710
711 query.append(_SQL_SELECT_DDMCONTENT_WHERE);
712
713 boolean bindUuid = false;
714
715 if (uuid == null) {
716 query.append(_FINDER_COLUMN_UUID_G_UUID_1);
717 }
718 else if (uuid.equals(StringPool.BLANK)) {
719 query.append(_FINDER_COLUMN_UUID_G_UUID_3);
720 }
721 else {
722 bindUuid = true;
723
724 query.append(_FINDER_COLUMN_UUID_G_UUID_2);
725 }
726
727 query.append(_FINDER_COLUMN_UUID_G_GROUPID_2);
728
729 String sql = query.toString();
730
731 Session session = null;
732
733 try {
734 session = openSession();
735
736 Query q = session.createQuery(sql);
737
738 QueryPos qPos = QueryPos.getInstance(q);
739
740 if (bindUuid) {
741 qPos.add(uuid);
742 }
743
744 qPos.add(groupId);
745
746 List<DDMContent> list = q.list();
747
748 if (list.isEmpty()) {
749 FinderCacheUtil.putResult(FINDER_PATH_FETCH_BY_UUID_G,
750 finderArgs, list);
751 }
752 else {
753 DDMContent ddmContent = list.get(0);
754
755 result = ddmContent;
756
757 cacheResult(ddmContent);
758
759 if ((ddmContent.getUuid() == null) ||
760 !ddmContent.getUuid().equals(uuid) ||
761 (ddmContent.getGroupId() != groupId)) {
762 FinderCacheUtil.putResult(FINDER_PATH_FETCH_BY_UUID_G,
763 finderArgs, ddmContent);
764 }
765 }
766 }
767 catch (Exception e) {
768 FinderCacheUtil.removeResult(FINDER_PATH_FETCH_BY_UUID_G,
769 finderArgs);
770
771 throw processException(e);
772 }
773 finally {
774 closeSession(session);
775 }
776 }
777
778 if (result instanceof List<?>) {
779 return null;
780 }
781 else {
782 return (DDMContent)result;
783 }
784 }
785
786
794 @Override
795 public DDMContent removeByUUID_G(String uuid, long groupId)
796 throws NoSuchContentException, SystemException {
797 DDMContent ddmContent = findByUUID_G(uuid, groupId);
798
799 return remove(ddmContent);
800 }
801
802
810 @Override
811 public int countByUUID_G(String uuid, long groupId)
812 throws SystemException {
813 FinderPath finderPath = FINDER_PATH_COUNT_BY_UUID_G;
814
815 Object[] finderArgs = new Object[] { uuid, groupId };
816
817 Long count = (Long)FinderCacheUtil.getResult(finderPath, finderArgs,
818 this);
819
820 if (count == null) {
821 StringBundler query = new StringBundler(3);
822
823 query.append(_SQL_COUNT_DDMCONTENT_WHERE);
824
825 boolean bindUuid = false;
826
827 if (uuid == null) {
828 query.append(_FINDER_COLUMN_UUID_G_UUID_1);
829 }
830 else if (uuid.equals(StringPool.BLANK)) {
831 query.append(_FINDER_COLUMN_UUID_G_UUID_3);
832 }
833 else {
834 bindUuid = true;
835
836 query.append(_FINDER_COLUMN_UUID_G_UUID_2);
837 }
838
839 query.append(_FINDER_COLUMN_UUID_G_GROUPID_2);
840
841 String sql = query.toString();
842
843 Session session = null;
844
845 try {
846 session = openSession();
847
848 Query q = session.createQuery(sql);
849
850 QueryPos qPos = QueryPos.getInstance(q);
851
852 if (bindUuid) {
853 qPos.add(uuid);
854 }
855
856 qPos.add(groupId);
857
858 count = (Long)q.uniqueResult();
859
860 FinderCacheUtil.putResult(finderPath, finderArgs, count);
861 }
862 catch (Exception e) {
863 FinderCacheUtil.removeResult(finderPath, finderArgs);
864
865 throw processException(e);
866 }
867 finally {
868 closeSession(session);
869 }
870 }
871
872 return count.intValue();
873 }
874
875 private static final String _FINDER_COLUMN_UUID_G_UUID_1 = "ddmContent.uuid IS NULL AND ";
876 private static final String _FINDER_COLUMN_UUID_G_UUID_2 = "ddmContent.uuid = ? AND ";
877 private static final String _FINDER_COLUMN_UUID_G_UUID_3 = "(ddmContent.uuid IS NULL OR ddmContent.uuid = '') AND ";
878 private static final String _FINDER_COLUMN_UUID_G_GROUPID_2 = "ddmContent.groupId = ?";
879 public static final FinderPath FINDER_PATH_WITH_PAGINATION_FIND_BY_UUID_C = new FinderPath(DDMContentModelImpl.ENTITY_CACHE_ENABLED,
880 DDMContentModelImpl.FINDER_CACHE_ENABLED, DDMContentImpl.class,
881 FINDER_CLASS_NAME_LIST_WITH_PAGINATION, "findByUuid_C",
882 new String[] {
883 String.class.getName(), Long.class.getName(),
884
885 Integer.class.getName(), Integer.class.getName(),
886 OrderByComparator.class.getName()
887 });
888 public static final FinderPath FINDER_PATH_WITHOUT_PAGINATION_FIND_BY_UUID_C =
889 new FinderPath(DDMContentModelImpl.ENTITY_CACHE_ENABLED,
890 DDMContentModelImpl.FINDER_CACHE_ENABLED, DDMContentImpl.class,
891 FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "findByUuid_C",
892 new String[] { String.class.getName(), Long.class.getName() },
893 DDMContentModelImpl.UUID_COLUMN_BITMASK |
894 DDMContentModelImpl.COMPANYID_COLUMN_BITMASK);
895 public static final FinderPath FINDER_PATH_COUNT_BY_UUID_C = new FinderPath(DDMContentModelImpl.ENTITY_CACHE_ENABLED,
896 DDMContentModelImpl.FINDER_CACHE_ENABLED, Long.class,
897 FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "countByUuid_C",
898 new String[] { String.class.getName(), Long.class.getName() });
899
900
908 @Override
909 public List<DDMContent> findByUuid_C(String uuid, long companyId)
910 throws SystemException {
911 return findByUuid_C(uuid, companyId, QueryUtil.ALL_POS,
912 QueryUtil.ALL_POS, null);
913 }
914
915
929 @Override
930 public List<DDMContent> findByUuid_C(String uuid, long companyId,
931 int start, int end) throws SystemException {
932 return findByUuid_C(uuid, companyId, start, end, null);
933 }
934
935
950 @Override
951 public List<DDMContent> findByUuid_C(String uuid, long companyId,
952 int start, int end, OrderByComparator orderByComparator)
953 throws SystemException {
954 boolean pagination = true;
955 FinderPath finderPath = null;
956 Object[] finderArgs = null;
957
958 if ((start == QueryUtil.ALL_POS) && (end == QueryUtil.ALL_POS) &&
959 (orderByComparator == null)) {
960 pagination = false;
961 finderPath = FINDER_PATH_WITHOUT_PAGINATION_FIND_BY_UUID_C;
962 finderArgs = new Object[] { uuid, companyId };
963 }
964 else {
965 finderPath = FINDER_PATH_WITH_PAGINATION_FIND_BY_UUID_C;
966 finderArgs = new Object[] {
967 uuid, companyId,
968
969 start, end, orderByComparator
970 };
971 }
972
973 List<DDMContent> list = (List<DDMContent>)FinderCacheUtil.getResult(finderPath,
974 finderArgs, this);
975
976 if ((list != null) && !list.isEmpty()) {
977 for (DDMContent ddmContent : list) {
978 if (!Validator.equals(uuid, ddmContent.getUuid()) ||
979 (companyId != ddmContent.getCompanyId())) {
980 list = null;
981
982 break;
983 }
984 }
985 }
986
987 if (list == null) {
988 StringBundler query = null;
989
990 if (orderByComparator != null) {
991 query = new StringBundler(4 +
992 (orderByComparator.getOrderByFields().length * 3));
993 }
994 else {
995 query = new StringBundler(4);
996 }
997
998 query.append(_SQL_SELECT_DDMCONTENT_WHERE);
999
1000 boolean bindUuid = false;
1001
1002 if (uuid == null) {
1003 query.append(_FINDER_COLUMN_UUID_C_UUID_1);
1004 }
1005 else if (uuid.equals(StringPool.BLANK)) {
1006 query.append(_FINDER_COLUMN_UUID_C_UUID_3);
1007 }
1008 else {
1009 bindUuid = true;
1010
1011 query.append(_FINDER_COLUMN_UUID_C_UUID_2);
1012 }
1013
1014 query.append(_FINDER_COLUMN_UUID_C_COMPANYID_2);
1015
1016 if (orderByComparator != null) {
1017 appendOrderByComparator(query, _ORDER_BY_ENTITY_ALIAS,
1018 orderByComparator);
1019 }
1020 else
1021 if (pagination) {
1022 query.append(DDMContentModelImpl.ORDER_BY_JPQL);
1023 }
1024
1025 String sql = query.toString();
1026
1027 Session session = null;
1028
1029 try {
1030 session = openSession();
1031
1032 Query q = session.createQuery(sql);
1033
1034 QueryPos qPos = QueryPos.getInstance(q);
1035
1036 if (bindUuid) {
1037 qPos.add(uuid);
1038 }
1039
1040 qPos.add(companyId);
1041
1042 if (!pagination) {
1043 list = (List<DDMContent>)QueryUtil.list(q, getDialect(),
1044 start, end, false);
1045
1046 Collections.sort(list);
1047
1048 list = new UnmodifiableList<DDMContent>(list);
1049 }
1050 else {
1051 list = (List<DDMContent>)QueryUtil.list(q, getDialect(),
1052 start, end);
1053 }
1054
1055 cacheResult(list);
1056
1057 FinderCacheUtil.putResult(finderPath, finderArgs, list);
1058 }
1059 catch (Exception e) {
1060 FinderCacheUtil.removeResult(finderPath, finderArgs);
1061
1062 throw processException(e);
1063 }
1064 finally {
1065 closeSession(session);
1066 }
1067 }
1068
1069 return list;
1070 }
1071
1072
1082 @Override
1083 public DDMContent findByUuid_C_First(String uuid, long companyId,
1084 OrderByComparator orderByComparator)
1085 throws NoSuchContentException, SystemException {
1086 DDMContent ddmContent = fetchByUuid_C_First(uuid, companyId,
1087 orderByComparator);
1088
1089 if (ddmContent != null) {
1090 return ddmContent;
1091 }
1092
1093 StringBundler msg = new StringBundler(6);
1094
1095 msg.append(_NO_SUCH_ENTITY_WITH_KEY);
1096
1097 msg.append("uuid=");
1098 msg.append(uuid);
1099
1100 msg.append(", companyId=");
1101 msg.append(companyId);
1102
1103 msg.append(StringPool.CLOSE_CURLY_BRACE);
1104
1105 throw new NoSuchContentException(msg.toString());
1106 }
1107
1108
1117 @Override
1118 public DDMContent fetchByUuid_C_First(String uuid, long companyId,
1119 OrderByComparator orderByComparator) throws SystemException {
1120 List<DDMContent> list = findByUuid_C(uuid, companyId, 0, 1,
1121 orderByComparator);
1122
1123 if (!list.isEmpty()) {
1124 return list.get(0);
1125 }
1126
1127 return null;
1128 }
1129
1130
1140 @Override
1141 public DDMContent findByUuid_C_Last(String uuid, long companyId,
1142 OrderByComparator orderByComparator)
1143 throws NoSuchContentException, SystemException {
1144 DDMContent ddmContent = fetchByUuid_C_Last(uuid, companyId,
1145 orderByComparator);
1146
1147 if (ddmContent != null) {
1148 return ddmContent;
1149 }
1150
1151 StringBundler msg = new StringBundler(6);
1152
1153 msg.append(_NO_SUCH_ENTITY_WITH_KEY);
1154
1155 msg.append("uuid=");
1156 msg.append(uuid);
1157
1158 msg.append(", companyId=");
1159 msg.append(companyId);
1160
1161 msg.append(StringPool.CLOSE_CURLY_BRACE);
1162
1163 throw new NoSuchContentException(msg.toString());
1164 }
1165
1166
1175 @Override
1176 public DDMContent fetchByUuid_C_Last(String uuid, long companyId,
1177 OrderByComparator orderByComparator) throws SystemException {
1178 int count = countByUuid_C(uuid, companyId);
1179
1180 if (count == 0) {
1181 return null;
1182 }
1183
1184 List<DDMContent> list = findByUuid_C(uuid, companyId, count - 1, count,
1185 orderByComparator);
1186
1187 if (!list.isEmpty()) {
1188 return list.get(0);
1189 }
1190
1191 return null;
1192 }
1193
1194
1205 @Override
1206 public DDMContent[] findByUuid_C_PrevAndNext(long contentId, String uuid,
1207 long companyId, OrderByComparator orderByComparator)
1208 throws NoSuchContentException, SystemException {
1209 DDMContent ddmContent = findByPrimaryKey(contentId);
1210
1211 Session session = null;
1212
1213 try {
1214 session = openSession();
1215
1216 DDMContent[] array = new DDMContentImpl[3];
1217
1218 array[0] = getByUuid_C_PrevAndNext(session, ddmContent, uuid,
1219 companyId, orderByComparator, true);
1220
1221 array[1] = ddmContent;
1222
1223 array[2] = getByUuid_C_PrevAndNext(session, ddmContent, uuid,
1224 companyId, orderByComparator, false);
1225
1226 return array;
1227 }
1228 catch (Exception e) {
1229 throw processException(e);
1230 }
1231 finally {
1232 closeSession(session);
1233 }
1234 }
1235
1236 protected DDMContent getByUuid_C_PrevAndNext(Session session,
1237 DDMContent ddmContent, String uuid, long companyId,
1238 OrderByComparator orderByComparator, boolean previous) {
1239 StringBundler query = null;
1240
1241 if (orderByComparator != null) {
1242 query = new StringBundler(6 +
1243 (orderByComparator.getOrderByFields().length * 6));
1244 }
1245 else {
1246 query = new StringBundler(3);
1247 }
1248
1249 query.append(_SQL_SELECT_DDMCONTENT_WHERE);
1250
1251 boolean bindUuid = false;
1252
1253 if (uuid == null) {
1254 query.append(_FINDER_COLUMN_UUID_C_UUID_1);
1255 }
1256 else if (uuid.equals(StringPool.BLANK)) {
1257 query.append(_FINDER_COLUMN_UUID_C_UUID_3);
1258 }
1259 else {
1260 bindUuid = true;
1261
1262 query.append(_FINDER_COLUMN_UUID_C_UUID_2);
1263 }
1264
1265 query.append(_FINDER_COLUMN_UUID_C_COMPANYID_2);
1266
1267 if (orderByComparator != null) {
1268 String[] orderByConditionFields = orderByComparator.getOrderByConditionFields();
1269
1270 if (orderByConditionFields.length > 0) {
1271 query.append(WHERE_AND);
1272 }
1273
1274 for (int i = 0; i < orderByConditionFields.length; i++) {
1275 query.append(_ORDER_BY_ENTITY_ALIAS);
1276 query.append(orderByConditionFields[i]);
1277
1278 if ((i + 1) < orderByConditionFields.length) {
1279 if (orderByComparator.isAscending() ^ previous) {
1280 query.append(WHERE_GREATER_THAN_HAS_NEXT);
1281 }
1282 else {
1283 query.append(WHERE_LESSER_THAN_HAS_NEXT);
1284 }
1285 }
1286 else {
1287 if (orderByComparator.isAscending() ^ previous) {
1288 query.append(WHERE_GREATER_THAN);
1289 }
1290 else {
1291 query.append(WHERE_LESSER_THAN);
1292 }
1293 }
1294 }
1295
1296 query.append(ORDER_BY_CLAUSE);
1297
1298 String[] orderByFields = orderByComparator.getOrderByFields();
1299
1300 for (int i = 0; i < orderByFields.length; i++) {
1301 query.append(_ORDER_BY_ENTITY_ALIAS);
1302 query.append(orderByFields[i]);
1303
1304 if ((i + 1) < orderByFields.length) {
1305 if (orderByComparator.isAscending() ^ previous) {
1306 query.append(ORDER_BY_ASC_HAS_NEXT);
1307 }
1308 else {
1309 query.append(ORDER_BY_DESC_HAS_NEXT);
1310 }
1311 }
1312 else {
1313 if (orderByComparator.isAscending() ^ previous) {
1314 query.append(ORDER_BY_ASC);
1315 }
1316 else {
1317 query.append(ORDER_BY_DESC);
1318 }
1319 }
1320 }
1321 }
1322 else {
1323 query.append(DDMContentModelImpl.ORDER_BY_JPQL);
1324 }
1325
1326 String sql = query.toString();
1327
1328 Query q = session.createQuery(sql);
1329
1330 q.setFirstResult(0);
1331 q.setMaxResults(2);
1332
1333 QueryPos qPos = QueryPos.getInstance(q);
1334
1335 if (bindUuid) {
1336 qPos.add(uuid);
1337 }
1338
1339 qPos.add(companyId);
1340
1341 if (orderByComparator != null) {
1342 Object[] values = orderByComparator.getOrderByConditionValues(ddmContent);
1343
1344 for (Object value : values) {
1345 qPos.add(value);
1346 }
1347 }
1348
1349 List<DDMContent> list = q.list();
1350
1351 if (list.size() == 2) {
1352 return list.get(1);
1353 }
1354 else {
1355 return null;
1356 }
1357 }
1358
1359
1366 @Override
1367 public void removeByUuid_C(String uuid, long companyId)
1368 throws SystemException {
1369 for (DDMContent ddmContent : findByUuid_C(uuid, companyId,
1370 QueryUtil.ALL_POS, QueryUtil.ALL_POS, null)) {
1371 remove(ddmContent);
1372 }
1373 }
1374
1375
1383 @Override
1384 public int countByUuid_C(String uuid, long companyId)
1385 throws SystemException {
1386 FinderPath finderPath = FINDER_PATH_COUNT_BY_UUID_C;
1387
1388 Object[] finderArgs = new Object[] { uuid, companyId };
1389
1390 Long count = (Long)FinderCacheUtil.getResult(finderPath, finderArgs,
1391 this);
1392
1393 if (count == null) {
1394 StringBundler query = new StringBundler(3);
1395
1396 query.append(_SQL_COUNT_DDMCONTENT_WHERE);
1397
1398 boolean bindUuid = false;
1399
1400 if (uuid == null) {
1401 query.append(_FINDER_COLUMN_UUID_C_UUID_1);
1402 }
1403 else if (uuid.equals(StringPool.BLANK)) {
1404 query.append(_FINDER_COLUMN_UUID_C_UUID_3);
1405 }
1406 else {
1407 bindUuid = true;
1408
1409 query.append(_FINDER_COLUMN_UUID_C_UUID_2);
1410 }
1411
1412 query.append(_FINDER_COLUMN_UUID_C_COMPANYID_2);
1413
1414 String sql = query.toString();
1415
1416 Session session = null;
1417
1418 try {
1419 session = openSession();
1420
1421 Query q = session.createQuery(sql);
1422
1423 QueryPos qPos = QueryPos.getInstance(q);
1424
1425 if (bindUuid) {
1426 qPos.add(uuid);
1427 }
1428
1429 qPos.add(companyId);
1430
1431 count = (Long)q.uniqueResult();
1432
1433 FinderCacheUtil.putResult(finderPath, finderArgs, count);
1434 }
1435 catch (Exception e) {
1436 FinderCacheUtil.removeResult(finderPath, finderArgs);
1437
1438 throw processException(e);
1439 }
1440 finally {
1441 closeSession(session);
1442 }
1443 }
1444
1445 return count.intValue();
1446 }
1447
1448 private static final String _FINDER_COLUMN_UUID_C_UUID_1 = "ddmContent.uuid IS NULL AND ";
1449 private static final String _FINDER_COLUMN_UUID_C_UUID_2 = "ddmContent.uuid = ? AND ";
1450 private static final String _FINDER_COLUMN_UUID_C_UUID_3 = "(ddmContent.uuid IS NULL OR ddmContent.uuid = '') AND ";
1451 private static final String _FINDER_COLUMN_UUID_C_COMPANYID_2 = "ddmContent.companyId = ?";
1452 public static final FinderPath FINDER_PATH_WITH_PAGINATION_FIND_BY_GROUPID = new FinderPath(DDMContentModelImpl.ENTITY_CACHE_ENABLED,
1453 DDMContentModelImpl.FINDER_CACHE_ENABLED, DDMContentImpl.class,
1454 FINDER_CLASS_NAME_LIST_WITH_PAGINATION, "findByGroupId",
1455 new String[] {
1456 Long.class.getName(),
1457
1458 Integer.class.getName(), Integer.class.getName(),
1459 OrderByComparator.class.getName()
1460 });
1461 public static final FinderPath FINDER_PATH_WITHOUT_PAGINATION_FIND_BY_GROUPID =
1462 new FinderPath(DDMContentModelImpl.ENTITY_CACHE_ENABLED,
1463 DDMContentModelImpl.FINDER_CACHE_ENABLED, DDMContentImpl.class,
1464 FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "findByGroupId",
1465 new String[] { Long.class.getName() },
1466 DDMContentModelImpl.GROUPID_COLUMN_BITMASK);
1467 public static final FinderPath FINDER_PATH_COUNT_BY_GROUPID = new FinderPath(DDMContentModelImpl.ENTITY_CACHE_ENABLED,
1468 DDMContentModelImpl.FINDER_CACHE_ENABLED, Long.class,
1469 FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "countByGroupId",
1470 new String[] { Long.class.getName() });
1471
1472
1479 @Override
1480 public List<DDMContent> findByGroupId(long groupId)
1481 throws SystemException {
1482 return findByGroupId(groupId, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null);
1483 }
1484
1485
1498 @Override
1499 public List<DDMContent> findByGroupId(long groupId, int start, int end)
1500 throws SystemException {
1501 return findByGroupId(groupId, start, end, null);
1502 }
1503
1504
1518 @Override
1519 public List<DDMContent> findByGroupId(long groupId, int start, int end,
1520 OrderByComparator orderByComparator) throws SystemException {
1521 boolean pagination = true;
1522 FinderPath finderPath = null;
1523 Object[] finderArgs = null;
1524
1525 if ((start == QueryUtil.ALL_POS) && (end == QueryUtil.ALL_POS) &&
1526 (orderByComparator == null)) {
1527 pagination = false;
1528 finderPath = FINDER_PATH_WITHOUT_PAGINATION_FIND_BY_GROUPID;
1529 finderArgs = new Object[] { groupId };
1530 }
1531 else {
1532 finderPath = FINDER_PATH_WITH_PAGINATION_FIND_BY_GROUPID;
1533 finderArgs = new Object[] { groupId, start, end, orderByComparator };
1534 }
1535
1536 List<DDMContent> list = (List<DDMContent>)FinderCacheUtil.getResult(finderPath,
1537 finderArgs, this);
1538
1539 if ((list != null) && !list.isEmpty()) {
1540 for (DDMContent ddmContent : list) {
1541 if ((groupId != ddmContent.getGroupId())) {
1542 list = null;
1543
1544 break;
1545 }
1546 }
1547 }
1548
1549 if (list == null) {
1550 StringBundler query = null;
1551
1552 if (orderByComparator != null) {
1553 query = new StringBundler(3 +
1554 (orderByComparator.getOrderByFields().length * 3));
1555 }
1556 else {
1557 query = new StringBundler(3);
1558 }
1559
1560 query.append(_SQL_SELECT_DDMCONTENT_WHERE);
1561
1562 query.append(_FINDER_COLUMN_GROUPID_GROUPID_2);
1563
1564 if (orderByComparator != null) {
1565 appendOrderByComparator(query, _ORDER_BY_ENTITY_ALIAS,
1566 orderByComparator);
1567 }
1568 else
1569 if (pagination) {
1570 query.append(DDMContentModelImpl.ORDER_BY_JPQL);
1571 }
1572
1573 String sql = query.toString();
1574
1575 Session session = null;
1576
1577 try {
1578 session = openSession();
1579
1580 Query q = session.createQuery(sql);
1581
1582 QueryPos qPos = QueryPos.getInstance(q);
1583
1584 qPos.add(groupId);
1585
1586 if (!pagination) {
1587 list = (List<DDMContent>)QueryUtil.list(q, getDialect(),
1588 start, end, false);
1589
1590 Collections.sort(list);
1591
1592 list = new UnmodifiableList<DDMContent>(list);
1593 }
1594 else {
1595 list = (List<DDMContent>)QueryUtil.list(q, getDialect(),
1596 start, end);
1597 }
1598
1599 cacheResult(list);
1600
1601 FinderCacheUtil.putResult(finderPath, finderArgs, list);
1602 }
1603 catch (Exception e) {
1604 FinderCacheUtil.removeResult(finderPath, finderArgs);
1605
1606 throw processException(e);
1607 }
1608 finally {
1609 closeSession(session);
1610 }
1611 }
1612
1613 return list;
1614 }
1615
1616
1625 @Override
1626 public DDMContent findByGroupId_First(long groupId,
1627 OrderByComparator orderByComparator)
1628 throws NoSuchContentException, SystemException {
1629 DDMContent ddmContent = fetchByGroupId_First(groupId, orderByComparator);
1630
1631 if (ddmContent != null) {
1632 return ddmContent;
1633 }
1634
1635 StringBundler msg = new StringBundler(4);
1636
1637 msg.append(_NO_SUCH_ENTITY_WITH_KEY);
1638
1639 msg.append("groupId=");
1640 msg.append(groupId);
1641
1642 msg.append(StringPool.CLOSE_CURLY_BRACE);
1643
1644 throw new NoSuchContentException(msg.toString());
1645 }
1646
1647
1655 @Override
1656 public DDMContent fetchByGroupId_First(long groupId,
1657 OrderByComparator orderByComparator) throws SystemException {
1658 List<DDMContent> list = findByGroupId(groupId, 0, 1, orderByComparator);
1659
1660 if (!list.isEmpty()) {
1661 return list.get(0);
1662 }
1663
1664 return null;
1665 }
1666
1667
1676 @Override
1677 public DDMContent findByGroupId_Last(long groupId,
1678 OrderByComparator orderByComparator)
1679 throws NoSuchContentException, SystemException {
1680 DDMContent ddmContent = fetchByGroupId_Last(groupId, orderByComparator);
1681
1682 if (ddmContent != null) {
1683 return ddmContent;
1684 }
1685
1686 StringBundler msg = new StringBundler(4);
1687
1688 msg.append(_NO_SUCH_ENTITY_WITH_KEY);
1689
1690 msg.append("groupId=");
1691 msg.append(groupId);
1692
1693 msg.append(StringPool.CLOSE_CURLY_BRACE);
1694
1695 throw new NoSuchContentException(msg.toString());
1696 }
1697
1698
1706 @Override
1707 public DDMContent fetchByGroupId_Last(long groupId,
1708 OrderByComparator orderByComparator) throws SystemException {
1709 int count = countByGroupId(groupId);
1710
1711 if (count == 0) {
1712 return null;
1713 }
1714
1715 List<DDMContent> list = findByGroupId(groupId, count - 1, count,
1716 orderByComparator);
1717
1718 if (!list.isEmpty()) {
1719 return list.get(0);
1720 }
1721
1722 return null;
1723 }
1724
1725
1735 @Override
1736 public DDMContent[] findByGroupId_PrevAndNext(long contentId, long groupId,
1737 OrderByComparator orderByComparator)
1738 throws NoSuchContentException, SystemException {
1739 DDMContent ddmContent = findByPrimaryKey(contentId);
1740
1741 Session session = null;
1742
1743 try {
1744 session = openSession();
1745
1746 DDMContent[] array = new DDMContentImpl[3];
1747
1748 array[0] = getByGroupId_PrevAndNext(session, ddmContent, groupId,
1749 orderByComparator, true);
1750
1751 array[1] = ddmContent;
1752
1753 array[2] = getByGroupId_PrevAndNext(session, ddmContent, groupId,
1754 orderByComparator, false);
1755
1756 return array;
1757 }
1758 catch (Exception e) {
1759 throw processException(e);
1760 }
1761 finally {
1762 closeSession(session);
1763 }
1764 }
1765
1766 protected DDMContent getByGroupId_PrevAndNext(Session session,
1767 DDMContent ddmContent, long groupId,
1768 OrderByComparator orderByComparator, boolean previous) {
1769 StringBundler query = null;
1770
1771 if (orderByComparator != null) {
1772 query = new StringBundler(6 +
1773 (orderByComparator.getOrderByFields().length * 6));
1774 }
1775 else {
1776 query = new StringBundler(3);
1777 }
1778
1779 query.append(_SQL_SELECT_DDMCONTENT_WHERE);
1780
1781 query.append(_FINDER_COLUMN_GROUPID_GROUPID_2);
1782
1783 if (orderByComparator != null) {
1784 String[] orderByConditionFields = orderByComparator.getOrderByConditionFields();
1785
1786 if (orderByConditionFields.length > 0) {
1787 query.append(WHERE_AND);
1788 }
1789
1790 for (int i = 0; i < orderByConditionFields.length; i++) {
1791 query.append(_ORDER_BY_ENTITY_ALIAS);
1792 query.append(orderByConditionFields[i]);
1793
1794 if ((i + 1) < orderByConditionFields.length) {
1795 if (orderByComparator.isAscending() ^ previous) {
1796 query.append(WHERE_GREATER_THAN_HAS_NEXT);
1797 }
1798 else {
1799 query.append(WHERE_LESSER_THAN_HAS_NEXT);
1800 }
1801 }
1802 else {
1803 if (orderByComparator.isAscending() ^ previous) {
1804 query.append(WHERE_GREATER_THAN);
1805 }
1806 else {
1807 query.append(WHERE_LESSER_THAN);
1808 }
1809 }
1810 }
1811
1812 query.append(ORDER_BY_CLAUSE);
1813
1814 String[] orderByFields = orderByComparator.getOrderByFields();
1815
1816 for (int i = 0; i < orderByFields.length; i++) {
1817 query.append(_ORDER_BY_ENTITY_ALIAS);
1818 query.append(orderByFields[i]);
1819
1820 if ((i + 1) < orderByFields.length) {
1821 if (orderByComparator.isAscending() ^ previous) {
1822 query.append(ORDER_BY_ASC_HAS_NEXT);
1823 }
1824 else {
1825 query.append(ORDER_BY_DESC_HAS_NEXT);
1826 }
1827 }
1828 else {
1829 if (orderByComparator.isAscending() ^ previous) {
1830 query.append(ORDER_BY_ASC);
1831 }
1832 else {
1833 query.append(ORDER_BY_DESC);
1834 }
1835 }
1836 }
1837 }
1838 else {
1839 query.append(DDMContentModelImpl.ORDER_BY_JPQL);
1840 }
1841
1842 String sql = query.toString();
1843
1844 Query q = session.createQuery(sql);
1845
1846 q.setFirstResult(0);
1847 q.setMaxResults(2);
1848
1849 QueryPos qPos = QueryPos.getInstance(q);
1850
1851 qPos.add(groupId);
1852
1853 if (orderByComparator != null) {
1854 Object[] values = orderByComparator.getOrderByConditionValues(ddmContent);
1855
1856 for (Object value : values) {
1857 qPos.add(value);
1858 }
1859 }
1860
1861 List<DDMContent> list = q.list();
1862
1863 if (list.size() == 2) {
1864 return list.get(1);
1865 }
1866 else {
1867 return null;
1868 }
1869 }
1870
1871
1877 @Override
1878 public void removeByGroupId(long groupId) throws SystemException {
1879 for (DDMContent ddmContent : findByGroupId(groupId, QueryUtil.ALL_POS,
1880 QueryUtil.ALL_POS, null)) {
1881 remove(ddmContent);
1882 }
1883 }
1884
1885
1892 @Override
1893 public int countByGroupId(long groupId) throws SystemException {
1894 FinderPath finderPath = FINDER_PATH_COUNT_BY_GROUPID;
1895
1896 Object[] finderArgs = new Object[] { groupId };
1897
1898 Long count = (Long)FinderCacheUtil.getResult(finderPath, finderArgs,
1899 this);
1900
1901 if (count == null) {
1902 StringBundler query = new StringBundler(2);
1903
1904 query.append(_SQL_COUNT_DDMCONTENT_WHERE);
1905
1906 query.append(_FINDER_COLUMN_GROUPID_GROUPID_2);
1907
1908 String sql = query.toString();
1909
1910 Session session = null;
1911
1912 try {
1913 session = openSession();
1914
1915 Query q = session.createQuery(sql);
1916
1917 QueryPos qPos = QueryPos.getInstance(q);
1918
1919 qPos.add(groupId);
1920
1921 count = (Long)q.uniqueResult();
1922
1923 FinderCacheUtil.putResult(finderPath, finderArgs, count);
1924 }
1925 catch (Exception e) {
1926 FinderCacheUtil.removeResult(finderPath, finderArgs);
1927
1928 throw processException(e);
1929 }
1930 finally {
1931 closeSession(session);
1932 }
1933 }
1934
1935 return count.intValue();
1936 }
1937
1938 private static final String _FINDER_COLUMN_GROUPID_GROUPID_2 = "ddmContent.groupId = ?";
1939 public static final FinderPath FINDER_PATH_WITH_PAGINATION_FIND_BY_COMPANYID =
1940 new FinderPath(DDMContentModelImpl.ENTITY_CACHE_ENABLED,
1941 DDMContentModelImpl.FINDER_CACHE_ENABLED, DDMContentImpl.class,
1942 FINDER_CLASS_NAME_LIST_WITH_PAGINATION, "findByCompanyId",
1943 new String[] {
1944 Long.class.getName(),
1945
1946 Integer.class.getName(), Integer.class.getName(),
1947 OrderByComparator.class.getName()
1948 });
1949 public static final FinderPath FINDER_PATH_WITHOUT_PAGINATION_FIND_BY_COMPANYID =
1950 new FinderPath(DDMContentModelImpl.ENTITY_CACHE_ENABLED,
1951 DDMContentModelImpl.FINDER_CACHE_ENABLED, DDMContentImpl.class,
1952 FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "findByCompanyId",
1953 new String[] { Long.class.getName() },
1954 DDMContentModelImpl.COMPANYID_COLUMN_BITMASK);
1955 public static final FinderPath FINDER_PATH_COUNT_BY_COMPANYID = new FinderPath(DDMContentModelImpl.ENTITY_CACHE_ENABLED,
1956 DDMContentModelImpl.FINDER_CACHE_ENABLED, Long.class,
1957 FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "countByCompanyId",
1958 new String[] { Long.class.getName() });
1959
1960
1967 @Override
1968 public List<DDMContent> findByCompanyId(long companyId)
1969 throws SystemException {
1970 return findByCompanyId(companyId, QueryUtil.ALL_POS, QueryUtil.ALL_POS,
1971 null);
1972 }
1973
1974
1987 @Override
1988 public List<DDMContent> findByCompanyId(long companyId, int start, int end)
1989 throws SystemException {
1990 return findByCompanyId(companyId, start, end, null);
1991 }
1992
1993
2007 @Override
2008 public List<DDMContent> findByCompanyId(long companyId, int start, int end,
2009 OrderByComparator orderByComparator) throws SystemException {
2010 boolean pagination = true;
2011 FinderPath finderPath = null;
2012 Object[] finderArgs = null;
2013
2014 if ((start == QueryUtil.ALL_POS) && (end == QueryUtil.ALL_POS) &&
2015 (orderByComparator == null)) {
2016 pagination = false;
2017 finderPath = FINDER_PATH_WITHOUT_PAGINATION_FIND_BY_COMPANYID;
2018 finderArgs = new Object[] { companyId };
2019 }
2020 else {
2021 finderPath = FINDER_PATH_WITH_PAGINATION_FIND_BY_COMPANYID;
2022 finderArgs = new Object[] { companyId, start, end, orderByComparator };
2023 }
2024
2025 List<DDMContent> list = (List<DDMContent>)FinderCacheUtil.getResult(finderPath,
2026 finderArgs, this);
2027
2028 if ((list != null) && !list.isEmpty()) {
2029 for (DDMContent ddmContent : list) {
2030 if ((companyId != ddmContent.getCompanyId())) {
2031 list = null;
2032
2033 break;
2034 }
2035 }
2036 }
2037
2038 if (list == null) {
2039 StringBundler query = null;
2040
2041 if (orderByComparator != null) {
2042 query = new StringBundler(3 +
2043 (orderByComparator.getOrderByFields().length * 3));
2044 }
2045 else {
2046 query = new StringBundler(3);
2047 }
2048
2049 query.append(_SQL_SELECT_DDMCONTENT_WHERE);
2050
2051 query.append(_FINDER_COLUMN_COMPANYID_COMPANYID_2);
2052
2053 if (orderByComparator != null) {
2054 appendOrderByComparator(query, _ORDER_BY_ENTITY_ALIAS,
2055 orderByComparator);
2056 }
2057 else
2058 if (pagination) {
2059 query.append(DDMContentModelImpl.ORDER_BY_JPQL);
2060 }
2061
2062 String sql = query.toString();
2063
2064 Session session = null;
2065
2066 try {
2067 session = openSession();
2068
2069 Query q = session.createQuery(sql);
2070
2071 QueryPos qPos = QueryPos.getInstance(q);
2072
2073 qPos.add(companyId);
2074
2075 if (!pagination) {
2076 list = (List<DDMContent>)QueryUtil.list(q, getDialect(),
2077 start, end, false);
2078
2079 Collections.sort(list);
2080
2081 list = new UnmodifiableList<DDMContent>(list);
2082 }
2083 else {
2084 list = (List<DDMContent>)QueryUtil.list(q, getDialect(),
2085 start, end);
2086 }
2087
2088 cacheResult(list);
2089
2090 FinderCacheUtil.putResult(finderPath, finderArgs, list);
2091 }
2092 catch (Exception e) {
2093 FinderCacheUtil.removeResult(finderPath, finderArgs);
2094
2095 throw processException(e);
2096 }
2097 finally {
2098 closeSession(session);
2099 }
2100 }
2101
2102 return list;
2103 }
2104
2105
2114 @Override
2115 public DDMContent findByCompanyId_First(long companyId,
2116 OrderByComparator orderByComparator)
2117 throws NoSuchContentException, SystemException {
2118 DDMContent ddmContent = fetchByCompanyId_First(companyId,
2119 orderByComparator);
2120
2121 if (ddmContent != null) {
2122 return ddmContent;
2123 }
2124
2125 StringBundler msg = new StringBundler(4);
2126
2127 msg.append(_NO_SUCH_ENTITY_WITH_KEY);
2128
2129 msg.append("companyId=");
2130 msg.append(companyId);
2131
2132 msg.append(StringPool.CLOSE_CURLY_BRACE);
2133
2134 throw new NoSuchContentException(msg.toString());
2135 }
2136
2137
2145 @Override
2146 public DDMContent fetchByCompanyId_First(long companyId,
2147 OrderByComparator orderByComparator) throws SystemException {
2148 List<DDMContent> list = findByCompanyId(companyId, 0, 1,
2149 orderByComparator);
2150
2151 if (!list.isEmpty()) {
2152 return list.get(0);
2153 }
2154
2155 return null;
2156 }
2157
2158
2167 @Override
2168 public DDMContent findByCompanyId_Last(long companyId,
2169 OrderByComparator orderByComparator)
2170 throws NoSuchContentException, SystemException {
2171 DDMContent ddmContent = fetchByCompanyId_Last(companyId,
2172 orderByComparator);
2173
2174 if (ddmContent != null) {
2175 return ddmContent;
2176 }
2177
2178 StringBundler msg = new StringBundler(4);
2179
2180 msg.append(_NO_SUCH_ENTITY_WITH_KEY);
2181
2182 msg.append("companyId=");
2183 msg.append(companyId);
2184
2185 msg.append(StringPool.CLOSE_CURLY_BRACE);
2186
2187 throw new NoSuchContentException(msg.toString());
2188 }
2189
2190
2198 @Override
2199 public DDMContent fetchByCompanyId_Last(long companyId,
2200 OrderByComparator orderByComparator) throws SystemException {
2201 int count = countByCompanyId(companyId);
2202
2203 if (count == 0) {
2204 return null;
2205 }
2206
2207 List<DDMContent> list = findByCompanyId(companyId, count - 1, count,
2208 orderByComparator);
2209
2210 if (!list.isEmpty()) {
2211 return list.get(0);
2212 }
2213
2214 return null;
2215 }
2216
2217
2227 @Override
2228 public DDMContent[] findByCompanyId_PrevAndNext(long contentId,
2229 long companyId, OrderByComparator orderByComparator)
2230 throws NoSuchContentException, SystemException {
2231 DDMContent ddmContent = findByPrimaryKey(contentId);
2232
2233 Session session = null;
2234
2235 try {
2236 session = openSession();
2237
2238 DDMContent[] array = new DDMContentImpl[3];
2239
2240 array[0] = getByCompanyId_PrevAndNext(session, ddmContent,
2241 companyId, orderByComparator, true);
2242
2243 array[1] = ddmContent;
2244
2245 array[2] = getByCompanyId_PrevAndNext(session, ddmContent,
2246 companyId, orderByComparator, false);
2247
2248 return array;
2249 }
2250 catch (Exception e) {
2251 throw processException(e);
2252 }
2253 finally {
2254 closeSession(session);
2255 }
2256 }
2257
2258 protected DDMContent getByCompanyId_PrevAndNext(Session session,
2259 DDMContent ddmContent, long companyId,
2260 OrderByComparator orderByComparator, boolean previous) {
2261 StringBundler query = null;
2262
2263 if (orderByComparator != null) {
2264 query = new StringBundler(6 +
2265 (orderByComparator.getOrderByFields().length * 6));
2266 }
2267 else {
2268 query = new StringBundler(3);
2269 }
2270
2271 query.append(_SQL_SELECT_DDMCONTENT_WHERE);
2272
2273 query.append(_FINDER_COLUMN_COMPANYID_COMPANYID_2);
2274
2275 if (orderByComparator != null) {
2276 String[] orderByConditionFields = orderByComparator.getOrderByConditionFields();
2277
2278 if (orderByConditionFields.length > 0) {
2279 query.append(WHERE_AND);
2280 }
2281
2282 for (int i = 0; i < orderByConditionFields.length; i++) {
2283 query.append(_ORDER_BY_ENTITY_ALIAS);
2284 query.append(orderByConditionFields[i]);
2285
2286 if ((i + 1) < orderByConditionFields.length) {
2287 if (orderByComparator.isAscending() ^ previous) {
2288 query.append(WHERE_GREATER_THAN_HAS_NEXT);
2289 }
2290 else {
2291 query.append(WHERE_LESSER_THAN_HAS_NEXT);
2292 }
2293 }
2294 else {
2295 if (orderByComparator.isAscending() ^ previous) {
2296 query.append(WHERE_GREATER_THAN);
2297 }
2298 else {
2299 query.append(WHERE_LESSER_THAN);
2300 }
2301 }
2302 }
2303
2304 query.append(ORDER_BY_CLAUSE);
2305
2306 String[] orderByFields = orderByComparator.getOrderByFields();
2307
2308 for (int i = 0; i < orderByFields.length; i++) {
2309 query.append(_ORDER_BY_ENTITY_ALIAS);
2310 query.append(orderByFields[i]);
2311
2312 if ((i + 1) < orderByFields.length) {
2313 if (orderByComparator.isAscending() ^ previous) {
2314 query.append(ORDER_BY_ASC_HAS_NEXT);
2315 }
2316 else {
2317 query.append(ORDER_BY_DESC_HAS_NEXT);
2318 }
2319 }
2320 else {
2321 if (orderByComparator.isAscending() ^ previous) {
2322 query.append(ORDER_BY_ASC);
2323 }
2324 else {
2325 query.append(ORDER_BY_DESC);
2326 }
2327 }
2328 }
2329 }
2330 else {
2331 query.append(DDMContentModelImpl.ORDER_BY_JPQL);
2332 }
2333
2334 String sql = query.toString();
2335
2336 Query q = session.createQuery(sql);
2337
2338 q.setFirstResult(0);
2339 q.setMaxResults(2);
2340
2341 QueryPos qPos = QueryPos.getInstance(q);
2342
2343 qPos.add(companyId);
2344
2345 if (orderByComparator != null) {
2346 Object[] values = orderByComparator.getOrderByConditionValues(ddmContent);
2347
2348 for (Object value : values) {
2349 qPos.add(value);
2350 }
2351 }
2352
2353 List<DDMContent> list = q.list();
2354
2355 if (list.size() == 2) {
2356 return list.get(1);
2357 }
2358 else {
2359 return null;
2360 }
2361 }
2362
2363
2369 @Override
2370 public void removeByCompanyId(long companyId) throws SystemException {
2371 for (DDMContent ddmContent : findByCompanyId(companyId,
2372 QueryUtil.ALL_POS, QueryUtil.ALL_POS, null)) {
2373 remove(ddmContent);
2374 }
2375 }
2376
2377
2384 @Override
2385 public int countByCompanyId(long companyId) throws SystemException {
2386 FinderPath finderPath = FINDER_PATH_COUNT_BY_COMPANYID;
2387
2388 Object[] finderArgs = new Object[] { companyId };
2389
2390 Long count = (Long)FinderCacheUtil.getResult(finderPath, finderArgs,
2391 this);
2392
2393 if (count == null) {
2394 StringBundler query = new StringBundler(2);
2395
2396 query.append(_SQL_COUNT_DDMCONTENT_WHERE);
2397
2398 query.append(_FINDER_COLUMN_COMPANYID_COMPANYID_2);
2399
2400 String sql = query.toString();
2401
2402 Session session = null;
2403
2404 try {
2405 session = openSession();
2406
2407 Query q = session.createQuery(sql);
2408
2409 QueryPos qPos = QueryPos.getInstance(q);
2410
2411 qPos.add(companyId);
2412
2413 count = (Long)q.uniqueResult();
2414
2415 FinderCacheUtil.putResult(finderPath, finderArgs, count);
2416 }
2417 catch (Exception e) {
2418 FinderCacheUtil.removeResult(finderPath, finderArgs);
2419
2420 throw processException(e);
2421 }
2422 finally {
2423 closeSession(session);
2424 }
2425 }
2426
2427 return count.intValue();
2428 }
2429
2430 private static final String _FINDER_COLUMN_COMPANYID_COMPANYID_2 = "ddmContent.companyId = ?";
2431
2432
2437 @Override
2438 public void cacheResult(DDMContent ddmContent) {
2439 EntityCacheUtil.putResult(DDMContentModelImpl.ENTITY_CACHE_ENABLED,
2440 DDMContentImpl.class, ddmContent.getPrimaryKey(), ddmContent);
2441
2442 FinderCacheUtil.putResult(FINDER_PATH_FETCH_BY_UUID_G,
2443 new Object[] { ddmContent.getUuid(), ddmContent.getGroupId() },
2444 ddmContent);
2445
2446 ddmContent.resetOriginalValues();
2447 }
2448
2449
2454 @Override
2455 public void cacheResult(List<DDMContent> ddmContents) {
2456 for (DDMContent ddmContent : ddmContents) {
2457 if (EntityCacheUtil.getResult(
2458 DDMContentModelImpl.ENTITY_CACHE_ENABLED,
2459 DDMContentImpl.class, ddmContent.getPrimaryKey()) == null) {
2460 cacheResult(ddmContent);
2461 }
2462 else {
2463 ddmContent.resetOriginalValues();
2464 }
2465 }
2466 }
2467
2468
2475 @Override
2476 public void clearCache() {
2477 if (_HIBERNATE_CACHE_USE_SECOND_LEVEL_CACHE) {
2478 CacheRegistryUtil.clear(DDMContentImpl.class.getName());
2479 }
2480
2481 EntityCacheUtil.clearCache(DDMContentImpl.class.getName());
2482
2483 FinderCacheUtil.clearCache(FINDER_CLASS_NAME_ENTITY);
2484 FinderCacheUtil.clearCache(FINDER_CLASS_NAME_LIST_WITH_PAGINATION);
2485 FinderCacheUtil.clearCache(FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION);
2486 }
2487
2488
2495 @Override
2496 public void clearCache(DDMContent ddmContent) {
2497 EntityCacheUtil.removeResult(DDMContentModelImpl.ENTITY_CACHE_ENABLED,
2498 DDMContentImpl.class, ddmContent.getPrimaryKey());
2499
2500 FinderCacheUtil.clearCache(FINDER_CLASS_NAME_LIST_WITH_PAGINATION);
2501 FinderCacheUtil.clearCache(FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION);
2502
2503 clearUniqueFindersCache(ddmContent);
2504 }
2505
2506 @Override
2507 public void clearCache(List<DDMContent> ddmContents) {
2508 FinderCacheUtil.clearCache(FINDER_CLASS_NAME_LIST_WITH_PAGINATION);
2509 FinderCacheUtil.clearCache(FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION);
2510
2511 for (DDMContent ddmContent : ddmContents) {
2512 EntityCacheUtil.removeResult(DDMContentModelImpl.ENTITY_CACHE_ENABLED,
2513 DDMContentImpl.class, ddmContent.getPrimaryKey());
2514
2515 clearUniqueFindersCache(ddmContent);
2516 }
2517 }
2518
2519 protected void cacheUniqueFindersCache(DDMContent ddmContent) {
2520 if (ddmContent.isNew()) {
2521 Object[] args = new Object[] {
2522 ddmContent.getUuid(), ddmContent.getGroupId()
2523 };
2524
2525 FinderCacheUtil.putResult(FINDER_PATH_COUNT_BY_UUID_G, args,
2526 Long.valueOf(1));
2527 FinderCacheUtil.putResult(FINDER_PATH_FETCH_BY_UUID_G, args,
2528 ddmContent);
2529 }
2530 else {
2531 DDMContentModelImpl ddmContentModelImpl = (DDMContentModelImpl)ddmContent;
2532
2533 if ((ddmContentModelImpl.getColumnBitmask() &
2534 FINDER_PATH_FETCH_BY_UUID_G.getColumnBitmask()) != 0) {
2535 Object[] args = new Object[] {
2536 ddmContent.getUuid(), ddmContent.getGroupId()
2537 };
2538
2539 FinderCacheUtil.putResult(FINDER_PATH_COUNT_BY_UUID_G, args,
2540 Long.valueOf(1));
2541 FinderCacheUtil.putResult(FINDER_PATH_FETCH_BY_UUID_G, args,
2542 ddmContent);
2543 }
2544 }
2545 }
2546
2547 protected void clearUniqueFindersCache(DDMContent ddmContent) {
2548 DDMContentModelImpl ddmContentModelImpl = (DDMContentModelImpl)ddmContent;
2549
2550 Object[] args = new Object[] {
2551 ddmContent.getUuid(), ddmContent.getGroupId()
2552 };
2553
2554 FinderCacheUtil.removeResult(FINDER_PATH_COUNT_BY_UUID_G, args);
2555 FinderCacheUtil.removeResult(FINDER_PATH_FETCH_BY_UUID_G, args);
2556
2557 if ((ddmContentModelImpl.getColumnBitmask() &
2558 FINDER_PATH_FETCH_BY_UUID_G.getColumnBitmask()) != 0) {
2559 args = new Object[] {
2560 ddmContentModelImpl.getOriginalUuid(),
2561 ddmContentModelImpl.getOriginalGroupId()
2562 };
2563
2564 FinderCacheUtil.removeResult(FINDER_PATH_COUNT_BY_UUID_G, args);
2565 FinderCacheUtil.removeResult(FINDER_PATH_FETCH_BY_UUID_G, args);
2566 }
2567 }
2568
2569
2575 @Override
2576 public DDMContent create(long contentId) {
2577 DDMContent ddmContent = new DDMContentImpl();
2578
2579 ddmContent.setNew(true);
2580 ddmContent.setPrimaryKey(contentId);
2581
2582 String uuid = PortalUUIDUtil.generate();
2583
2584 ddmContent.setUuid(uuid);
2585
2586 return ddmContent;
2587 }
2588
2589
2597 @Override
2598 public DDMContent remove(long contentId)
2599 throws NoSuchContentException, SystemException {
2600 return remove((Serializable)contentId);
2601 }
2602
2603
2611 @Override
2612 public DDMContent remove(Serializable primaryKey)
2613 throws NoSuchContentException, SystemException {
2614 Session session = null;
2615
2616 try {
2617 session = openSession();
2618
2619 DDMContent ddmContent = (DDMContent)session.get(DDMContentImpl.class,
2620 primaryKey);
2621
2622 if (ddmContent == null) {
2623 if (_log.isWarnEnabled()) {
2624 _log.warn(_NO_SUCH_ENTITY_WITH_PRIMARY_KEY + primaryKey);
2625 }
2626
2627 throw new NoSuchContentException(_NO_SUCH_ENTITY_WITH_PRIMARY_KEY +
2628 primaryKey);
2629 }
2630
2631 return remove(ddmContent);
2632 }
2633 catch (NoSuchContentException nsee) {
2634 throw nsee;
2635 }
2636 catch (Exception e) {
2637 throw processException(e);
2638 }
2639 finally {
2640 closeSession(session);
2641 }
2642 }
2643
2644 @Override
2645 protected DDMContent removeImpl(DDMContent ddmContent)
2646 throws SystemException {
2647 ddmContent = toUnwrappedModel(ddmContent);
2648
2649 Session session = null;
2650
2651 try {
2652 session = openSession();
2653
2654 if (!session.contains(ddmContent)) {
2655 ddmContent = (DDMContent)session.get(DDMContentImpl.class,
2656 ddmContent.getPrimaryKeyObj());
2657 }
2658
2659 if (ddmContent != null) {
2660 session.delete(ddmContent);
2661 }
2662 }
2663 catch (Exception e) {
2664 throw processException(e);
2665 }
2666 finally {
2667 closeSession(session);
2668 }
2669
2670 if (ddmContent != null) {
2671 clearCache(ddmContent);
2672 }
2673
2674 return ddmContent;
2675 }
2676
2677 @Override
2678 public DDMContent updateImpl(
2679 com.liferay.portlet.dynamicdatamapping.model.DDMContent ddmContent)
2680 throws SystemException {
2681 ddmContent = toUnwrappedModel(ddmContent);
2682
2683 boolean isNew = ddmContent.isNew();
2684
2685 DDMContentModelImpl ddmContentModelImpl = (DDMContentModelImpl)ddmContent;
2686
2687 if (Validator.isNull(ddmContent.getUuid())) {
2688 String uuid = PortalUUIDUtil.generate();
2689
2690 ddmContent.setUuid(uuid);
2691 }
2692
2693 Session session = null;
2694
2695 try {
2696 session = openSession();
2697
2698 if (ddmContent.isNew()) {
2699 session.save(ddmContent);
2700
2701 ddmContent.setNew(false);
2702 }
2703 else {
2704 session.merge(ddmContent);
2705 }
2706 }
2707 catch (Exception e) {
2708 throw processException(e);
2709 }
2710 finally {
2711 closeSession(session);
2712 }
2713
2714 FinderCacheUtil.clearCache(FINDER_CLASS_NAME_LIST_WITH_PAGINATION);
2715
2716 if (isNew || !DDMContentModelImpl.COLUMN_BITMASK_ENABLED) {
2717 FinderCacheUtil.clearCache(FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION);
2718 }
2719
2720 else {
2721 if ((ddmContentModelImpl.getColumnBitmask() &
2722 FINDER_PATH_WITHOUT_PAGINATION_FIND_BY_UUID.getColumnBitmask()) != 0) {
2723 Object[] args = new Object[] {
2724 ddmContentModelImpl.getOriginalUuid()
2725 };
2726
2727 FinderCacheUtil.removeResult(FINDER_PATH_COUNT_BY_UUID, args);
2728 FinderCacheUtil.removeResult(FINDER_PATH_WITHOUT_PAGINATION_FIND_BY_UUID,
2729 args);
2730
2731 args = new Object[] { ddmContentModelImpl.getUuid() };
2732
2733 FinderCacheUtil.removeResult(FINDER_PATH_COUNT_BY_UUID, args);
2734 FinderCacheUtil.removeResult(FINDER_PATH_WITHOUT_PAGINATION_FIND_BY_UUID,
2735 args);
2736 }
2737
2738 if ((ddmContentModelImpl.getColumnBitmask() &
2739 FINDER_PATH_WITHOUT_PAGINATION_FIND_BY_UUID_C.getColumnBitmask()) != 0) {
2740 Object[] args = new Object[] {
2741 ddmContentModelImpl.getOriginalUuid(),
2742 ddmContentModelImpl.getOriginalCompanyId()
2743 };
2744
2745 FinderCacheUtil.removeResult(FINDER_PATH_COUNT_BY_UUID_C, args);
2746 FinderCacheUtil.removeResult(FINDER_PATH_WITHOUT_PAGINATION_FIND_BY_UUID_C,
2747 args);
2748
2749 args = new Object[] {
2750 ddmContentModelImpl.getUuid(),
2751 ddmContentModelImpl.getCompanyId()
2752 };
2753
2754 FinderCacheUtil.removeResult(FINDER_PATH_COUNT_BY_UUID_C, args);
2755 FinderCacheUtil.removeResult(FINDER_PATH_WITHOUT_PAGINATION_FIND_BY_UUID_C,
2756 args);
2757 }
2758
2759 if ((ddmContentModelImpl.getColumnBitmask() &
2760 FINDER_PATH_WITHOUT_PAGINATION_FIND_BY_GROUPID.getColumnBitmask()) != 0) {
2761 Object[] args = new Object[] {
2762 ddmContentModelImpl.getOriginalGroupId()
2763 };
2764
2765 FinderCacheUtil.removeResult(FINDER_PATH_COUNT_BY_GROUPID, args);
2766 FinderCacheUtil.removeResult(FINDER_PATH_WITHOUT_PAGINATION_FIND_BY_GROUPID,
2767 args);
2768
2769 args = new Object[] { ddmContentModelImpl.getGroupId() };
2770
2771 FinderCacheUtil.removeResult(FINDER_PATH_COUNT_BY_GROUPID, args);
2772 FinderCacheUtil.removeResult(FINDER_PATH_WITHOUT_PAGINATION_FIND_BY_GROUPID,
2773 args);
2774 }
2775
2776 if ((ddmContentModelImpl.getColumnBitmask() &
2777 FINDER_PATH_WITHOUT_PAGINATION_FIND_BY_COMPANYID.getColumnBitmask()) != 0) {
2778 Object[] args = new Object[] {
2779 ddmContentModelImpl.getOriginalCompanyId()
2780 };
2781
2782 FinderCacheUtil.removeResult(FINDER_PATH_COUNT_BY_COMPANYID,
2783 args);
2784 FinderCacheUtil.removeResult(FINDER_PATH_WITHOUT_PAGINATION_FIND_BY_COMPANYID,
2785 args);
2786
2787 args = new Object[] { ddmContentModelImpl.getCompanyId() };
2788
2789 FinderCacheUtil.removeResult(FINDER_PATH_COUNT_BY_COMPANYID,
2790 args);
2791 FinderCacheUtil.removeResult(FINDER_PATH_WITHOUT_PAGINATION_FIND_BY_COMPANYID,
2792 args);
2793 }
2794 }
2795
2796 EntityCacheUtil.putResult(DDMContentModelImpl.ENTITY_CACHE_ENABLED,
2797 DDMContentImpl.class, ddmContent.getPrimaryKey(), ddmContent);
2798
2799 clearUniqueFindersCache(ddmContent);
2800 cacheUniqueFindersCache(ddmContent);
2801
2802 return ddmContent;
2803 }
2804
2805 protected DDMContent toUnwrappedModel(DDMContent ddmContent) {
2806 if (ddmContent instanceof DDMContentImpl) {
2807 return ddmContent;
2808 }
2809
2810 DDMContentImpl ddmContentImpl = new DDMContentImpl();
2811
2812 ddmContentImpl.setNew(ddmContent.isNew());
2813 ddmContentImpl.setPrimaryKey(ddmContent.getPrimaryKey());
2814
2815 ddmContentImpl.setUuid(ddmContent.getUuid());
2816 ddmContentImpl.setContentId(ddmContent.getContentId());
2817 ddmContentImpl.setGroupId(ddmContent.getGroupId());
2818 ddmContentImpl.setCompanyId(ddmContent.getCompanyId());
2819 ddmContentImpl.setUserId(ddmContent.getUserId());
2820 ddmContentImpl.setUserName(ddmContent.getUserName());
2821 ddmContentImpl.setCreateDate(ddmContent.getCreateDate());
2822 ddmContentImpl.setModifiedDate(ddmContent.getModifiedDate());
2823 ddmContentImpl.setName(ddmContent.getName());
2824 ddmContentImpl.setDescription(ddmContent.getDescription());
2825 ddmContentImpl.setXml(ddmContent.getXml());
2826
2827 return ddmContentImpl;
2828 }
2829
2830
2838 @Override
2839 public DDMContent findByPrimaryKey(Serializable primaryKey)
2840 throws NoSuchContentException, SystemException {
2841 DDMContent ddmContent = fetchByPrimaryKey(primaryKey);
2842
2843 if (ddmContent == null) {
2844 if (_log.isWarnEnabled()) {
2845 _log.warn(_NO_SUCH_ENTITY_WITH_PRIMARY_KEY + primaryKey);
2846 }
2847
2848 throw new NoSuchContentException(_NO_SUCH_ENTITY_WITH_PRIMARY_KEY +
2849 primaryKey);
2850 }
2851
2852 return ddmContent;
2853 }
2854
2855
2863 @Override
2864 public DDMContent findByPrimaryKey(long contentId)
2865 throws NoSuchContentException, SystemException {
2866 return findByPrimaryKey((Serializable)contentId);
2867 }
2868
2869
2876 @Override
2877 public DDMContent fetchByPrimaryKey(Serializable primaryKey)
2878 throws SystemException {
2879 DDMContent ddmContent = (DDMContent)EntityCacheUtil.getResult(DDMContentModelImpl.ENTITY_CACHE_ENABLED,
2880 DDMContentImpl.class, primaryKey);
2881
2882 if (ddmContent == _nullDDMContent) {
2883 return null;
2884 }
2885
2886 if (ddmContent == null) {
2887 Session session = null;
2888
2889 try {
2890 session = openSession();
2891
2892 ddmContent = (DDMContent)session.get(DDMContentImpl.class,
2893 primaryKey);
2894
2895 if (ddmContent != null) {
2896 cacheResult(ddmContent);
2897 }
2898 else {
2899 EntityCacheUtil.putResult(DDMContentModelImpl.ENTITY_CACHE_ENABLED,
2900 DDMContentImpl.class, primaryKey, _nullDDMContent);
2901 }
2902 }
2903 catch (Exception e) {
2904 EntityCacheUtil.removeResult(DDMContentModelImpl.ENTITY_CACHE_ENABLED,
2905 DDMContentImpl.class, primaryKey);
2906
2907 throw processException(e);
2908 }
2909 finally {
2910 closeSession(session);
2911 }
2912 }
2913
2914 return ddmContent;
2915 }
2916
2917
2924 @Override
2925 public DDMContent fetchByPrimaryKey(long contentId)
2926 throws SystemException {
2927 return fetchByPrimaryKey((Serializable)contentId);
2928 }
2929
2930
2936 @Override
2937 public List<DDMContent> findAll() throws SystemException {
2938 return findAll(QueryUtil.ALL_POS, QueryUtil.ALL_POS, null);
2939 }
2940
2941
2953 @Override
2954 public List<DDMContent> findAll(int start, int end)
2955 throws SystemException {
2956 return findAll(start, end, null);
2957 }
2958
2959
2972 @Override
2973 public List<DDMContent> findAll(int start, int end,
2974 OrderByComparator orderByComparator) throws SystemException {
2975 boolean pagination = true;
2976 FinderPath finderPath = null;
2977 Object[] finderArgs = null;
2978
2979 if ((start == QueryUtil.ALL_POS) && (end == QueryUtil.ALL_POS) &&
2980 (orderByComparator == null)) {
2981 pagination = false;
2982 finderPath = FINDER_PATH_WITHOUT_PAGINATION_FIND_ALL;
2983 finderArgs = FINDER_ARGS_EMPTY;
2984 }
2985 else {
2986 finderPath = FINDER_PATH_WITH_PAGINATION_FIND_ALL;
2987 finderArgs = new Object[] { start, end, orderByComparator };
2988 }
2989
2990 List<DDMContent> list = (List<DDMContent>)FinderCacheUtil.getResult(finderPath,
2991 finderArgs, this);
2992
2993 if (list == null) {
2994 StringBundler query = null;
2995 String sql = null;
2996
2997 if (orderByComparator != null) {
2998 query = new StringBundler(2 +
2999 (orderByComparator.getOrderByFields().length * 3));
3000
3001 query.append(_SQL_SELECT_DDMCONTENT);
3002
3003 appendOrderByComparator(query, _ORDER_BY_ENTITY_ALIAS,
3004 orderByComparator);
3005
3006 sql = query.toString();
3007 }
3008 else {
3009 sql = _SQL_SELECT_DDMCONTENT;
3010
3011 if (pagination) {
3012 sql = sql.concat(DDMContentModelImpl.ORDER_BY_JPQL);
3013 }
3014 }
3015
3016 Session session = null;
3017
3018 try {
3019 session = openSession();
3020
3021 Query q = session.createQuery(sql);
3022
3023 if (!pagination) {
3024 list = (List<DDMContent>)QueryUtil.list(q, getDialect(),
3025 start, end, false);
3026
3027 Collections.sort(list);
3028
3029 list = new UnmodifiableList<DDMContent>(list);
3030 }
3031 else {
3032 list = (List<DDMContent>)QueryUtil.list(q, getDialect(),
3033 start, end);
3034 }
3035
3036 cacheResult(list);
3037
3038 FinderCacheUtil.putResult(finderPath, finderArgs, list);
3039 }
3040 catch (Exception e) {
3041 FinderCacheUtil.removeResult(finderPath, finderArgs);
3042
3043 throw processException(e);
3044 }
3045 finally {
3046 closeSession(session);
3047 }
3048 }
3049
3050 return list;
3051 }
3052
3053
3058 @Override
3059 public void removeAll() throws SystemException {
3060 for (DDMContent ddmContent : findAll()) {
3061 remove(ddmContent);
3062 }
3063 }
3064
3065
3071 @Override
3072 public int countAll() throws SystemException {
3073 Long count = (Long)FinderCacheUtil.getResult(FINDER_PATH_COUNT_ALL,
3074 FINDER_ARGS_EMPTY, this);
3075
3076 if (count == null) {
3077 Session session = null;
3078
3079 try {
3080 session = openSession();
3081
3082 Query q = session.createQuery(_SQL_COUNT_DDMCONTENT);
3083
3084 count = (Long)q.uniqueResult();
3085
3086 FinderCacheUtil.putResult(FINDER_PATH_COUNT_ALL,
3087 FINDER_ARGS_EMPTY, count);
3088 }
3089 catch (Exception e) {
3090 FinderCacheUtil.removeResult(FINDER_PATH_COUNT_ALL,
3091 FINDER_ARGS_EMPTY);
3092
3093 throw processException(e);
3094 }
3095 finally {
3096 closeSession(session);
3097 }
3098 }
3099
3100 return count.intValue();
3101 }
3102
3103 @Override
3104 protected Set<String> getBadColumnNames() {
3105 return _badColumnNames;
3106 }
3107
3108
3111 public void afterPropertiesSet() {
3112 String[] listenerClassNames = StringUtil.split(GetterUtil.getString(
3113 com.liferay.portal.util.PropsUtil.get(
3114 "value.object.listener.com.liferay.portlet.dynamicdatamapping.model.DDMContent")));
3115
3116 if (listenerClassNames.length > 0) {
3117 try {
3118 List<ModelListener<DDMContent>> listenersList = new ArrayList<ModelListener<DDMContent>>();
3119
3120 for (String listenerClassName : listenerClassNames) {
3121 listenersList.add((ModelListener<DDMContent>)InstanceFactory.newInstance(
3122 getClassLoader(), listenerClassName));
3123 }
3124
3125 listeners = listenersList.toArray(new ModelListener[listenersList.size()]);
3126 }
3127 catch (Exception e) {
3128 _log.error(e);
3129 }
3130 }
3131 }
3132
3133 public void destroy() {
3134 EntityCacheUtil.removeCache(DDMContentImpl.class.getName());
3135 FinderCacheUtil.removeCache(FINDER_CLASS_NAME_ENTITY);
3136 FinderCacheUtil.removeCache(FINDER_CLASS_NAME_LIST_WITH_PAGINATION);
3137 FinderCacheUtil.removeCache(FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION);
3138 }
3139
3140 private static final String _SQL_SELECT_DDMCONTENT = "SELECT ddmContent FROM DDMContent ddmContent";
3141 private static final String _SQL_SELECT_DDMCONTENT_WHERE = "SELECT ddmContent FROM DDMContent ddmContent WHERE ";
3142 private static final String _SQL_COUNT_DDMCONTENT = "SELECT COUNT(ddmContent) FROM DDMContent ddmContent";
3143 private static final String _SQL_COUNT_DDMCONTENT_WHERE = "SELECT COUNT(ddmContent) FROM DDMContent ddmContent WHERE ";
3144 private static final String _ORDER_BY_ENTITY_ALIAS = "ddmContent.";
3145 private static final String _NO_SUCH_ENTITY_WITH_PRIMARY_KEY = "No DDMContent exists with the primary key ";
3146 private static final String _NO_SUCH_ENTITY_WITH_KEY = "No DDMContent exists with the key {";
3147 private static final boolean _HIBERNATE_CACHE_USE_SECOND_LEVEL_CACHE = com.liferay.portal.util.PropsValues.HIBERNATE_CACHE_USE_SECOND_LEVEL_CACHE;
3148 private static Log _log = LogFactoryUtil.getLog(DDMContentPersistenceImpl.class);
3149 private static Set<String> _badColumnNames = SetUtil.fromArray(new String[] {
3150 "uuid"
3151 });
3152 private static DDMContent _nullDDMContent = new DDMContentImpl() {
3153 @Override
3154 public Object clone() {
3155 return this;
3156 }
3157
3158 @Override
3159 public CacheModel<DDMContent> toCacheModel() {
3160 return _nullDDMContentCacheModel;
3161 }
3162 };
3163
3164 private static CacheModel<DDMContent> _nullDDMContentCacheModel = new CacheModel<DDMContent>() {
3165 @Override
3166 public DDMContent toEntityModel() {
3167 return _nullDDMContent;
3168 }
3169 };
3170 }