Package org.hibernate.type

Examples of org.hibernate.type.CollectionType


        return null;
      }
      return getEntity( session.generateEntityKey( owenerId, ownerPersister ) );
    }

    final CollectionType collectionType = collectionPersister.getCollectionType();

    //    2) The incoming key is most likely the collection key which we need to resolve to the owner key
    //      find the corresponding owner instance
    //      a) try by EntityUniqueKey
    if ( collectionType.getLHSPropertyName() != null ) {
      Object owner = getEntity(
          new EntityUniqueKey(
              ownerPersister.getEntityName(),
              collectionType.getLHSPropertyName(),
              key,
              collectionPersister.getKeyType(),
              ownerPersister.getEntityMode(),
              session.getFactory()
          )
      );
      if ( owner != null ) {
        return owner;
      }

      //    b) try by EntityKey, which means we need to resolve owner-key -> collection-key
      //      IMPL NOTE : yes if we get here this impl is very non-performant, but PersistenceContext
      //          was never designed to handle this case; adding that capability for real means splitting
      //          the notions of:
      //            1) collection key
      //            2) collection owner key
      //           these 2 are not always the same (same is true in the case of ToOne associations with
      //           property-ref).  That would require changes to (at least) CollectionEntry and quite
      //          probably changes to how the sql for collection initializers are generated
      //
      //      We could also possibly see if the referenced property is a natural id since we already have caching
      //      in place of natural id snapshots.  BUt really its better to just do it the right way ^^ if we start
      //       going that route
      final Serializable ownerId = ownerPersister.getIdByUniqueKey( key, collectionType.getLHSPropertyName(), session );
      return getEntity( session.generateEntityKey( ownerId, ownerPersister ) );
    }

    // as a last resort this is what the old code did...
    return getEntity( session.generateEntityKey( key, collectionPersister.getOwnerEntityPersister() ) );
View Full Code Here


    }

    final SessionFactoryImplementor sessionFactory = ((SessionImplementor) session).getFactory();
    final Type propertyType = sessionFactory.getEntityPersister( entityName ).getPropertyType( propertyName );
    if ( propertyType.isCollectionType() ) {
      CollectionType collectionPropertyType = (CollectionType) propertyType;
      // Handling collection of components.
      if ( collectionPropertyType.getElementType( sessionFactory ) instanceof ComponentType ) {
        // Adding restrictions to compare data outside of primary key.
        for ( Map.Entry<String, Object> dataEntry : persistentCollectionChangeData.getData().entrySet() ) {
          if ( !originalIdPropName.equals( dataEntry.getKey() ) ) {
            qb.getRootParameters().addWhereWithParam( dataEntry.getKey(), true, "=", dataEntry.getValue() );
          }
View Full Code Here

      return checkComponentNullability( value, (CompositeType) propertyType );
    }
    else if ( propertyType.isCollectionType() ) {

      //persistent collections may have components
      CollectionType collectionType = (CollectionType) propertyType;
      Type collectionElementType = collectionType.getElementType( session.getFactory() );
      if ( collectionElementType.isComponentType() ) {
        //check for all components values in the collection

        CompositeType componentType = (CompositeType) collectionElementType;
        Iterator iter = CascadingActions.getLoadedElementsIterator( session, collectionType, value );
View Full Code Here

        return null;
      }
      return getEntity( session.generateEntityKey( owenerId, ownerPersister ) );
    }

    final CollectionType collectionType = collectionPersister.getCollectionType();

    //    2) The incoming key is most likely the collection key which we need to resolve to the owner key
    //      find the corresponding owner instance
    //      a) try by EntityUniqueKey
    if ( collectionType.getLHSPropertyName() != null ) {
      final Object owner = getEntity(
          new EntityUniqueKey(
              ownerPersister.getEntityName(),
              collectionType.getLHSPropertyName(),
              key,
              collectionPersister.getKeyType(),
              ownerPersister.getEntityMode(),
              session.getFactory()
          )
      );
      if ( owner != null ) {
        return owner;
      }

      //    b) try by EntityKey, which means we need to resolve owner-key -> collection-key
      //      IMPL NOTE : yes if we get here this impl is very non-performant, but PersistenceContext
      //          was never designed to handle this case; adding that capability for real means splitting
      //          the notions of:
      //            1) collection key
      //            2) collection owner key
      //           these 2 are not always the same (same is true in the case of ToOne associations with
      //           property-ref).  That would require changes to (at least) CollectionEntry and quite
      //          probably changes to how the sql for collection initializers are generated
      //
      //      We could also possibly see if the referenced property is a natural id since we already have caching
      //      in place of natural id snapshots.  BUt really its better to just do it the right way ^^ if we start
      //       going that route
      final Serializable ownerId = ownerPersister.getIdByUniqueKey( key, collectionType.getLHSPropertyName(), session );
      return getEntity( session.generateEntityKey( ownerId, ownerPersister ) );
    }

    // as a last resort this is what the old code did...
    return getEntity( session.generateEntityKey( key, collectionPersister.getOwnerEntityPersister() ) );
View Full Code Here

      componentPath += tokens.nextToken();
      Type type = provider.getType( componentPath );
      if ( type.isAssociationType() ) {
        // CollectionTypes are always also AssociationTypes - but there's not always an associated entity...
        AssociationType atype = ( AssociationType ) type;
        CollectionType ctype = type.isCollectionType() ? (CollectionType)type : null;
        Type elementType = (ctype != null) ? ctype.getElementType( sessionFactory ) : null;
        // is the association a collection of components or value-types? (i.e a colloction of valued types?)
        if ( ctype != null  && elementType.isComponentType() ) {
          provider = new ComponentCollectionCriteriaInfoProvider( helper.getCollectionPersister(ctype.getRole()) );
        }
        else if ( ctype != null && !elementType.isEntityType() ) {
          provider = new ScalarCollectionCriteriaInfoProvider( helper, ctype.getRole() );
        }
        else {
          provider = new EntityCriteriaInfoProvider(( Queryable ) sessionFactory.getEntityPersister(
                        atype.getAssociatedEntityName( sessionFactory )
                        ));
View Full Code Here

      return checkComponentNullability( value, (CompositeType) propertyType );
    }
    else if ( propertyType.isCollectionType() ) {

      //persistent collections may have components
      final CollectionType collectionType = (CollectionType) propertyType;
      final Type collectionElementType = collectionType.getElementType( session.getFactory() );
      if ( collectionElementType.isComponentType() ) {
        //check for all components values in the collection

        final CompositeType componentType = (CompositeType) collectionElementType;
        final Iterator itr = CascadingActions.getLoadedElementsIterator( session, collectionType, value );
View Full Code Here

    deletes = new ArrayList<String>();
   
    // If many-to-many, delete the FK row in the collection table.
    for ( Type type : targetedPersister.getPropertyTypes() ) {
      if ( type.isCollectionType() ) {
        CollectionType cType = (CollectionType) type;
        AbstractCollectionPersister cPersister = (AbstractCollectionPersister)factory.getCollectionPersister( cType.getRole() );
        if ( cPersister.isManyToMany() ) {
          deletes.add( generateDelete( cPersister.getTableName(),
              cPersister.getKeyColumnNames(), idSubselect, "bulk delete - m2m join table cleanup"));
        }
      }
View Full Code Here

    deletes = new ArrayList<String>();
   
    // If many-to-many, delete the FK row in the collection table.
    for ( Type type : targetedPersister.getPropertyTypes() ) {
      if ( type.isCollectionType() ) {
        CollectionType cType = (CollectionType) type;
        AbstractCollectionPersister cPersister = (AbstractCollectionPersister)factory.getCollectionPersister( cType.getRole() );
        if ( cPersister.isManyToMany() ) {
          deletes.add( generateDelete( cPersister.getTableName(),
              cPersister.getKeyColumnNames(), idSubselect, "bulk delete - m2m join table cleanup"));
        }
      }
View Full Code Here

        return null;
      }
      return getEntity( session.generateEntityKey( owenerId, ownerPersister ) );
    }

    final CollectionType collectionType = collectionPersister.getCollectionType();

    //    2) The incoming key is most likely the collection key which we need to resolve to the owner key
    //      find the corresponding owner instance
    //      a) try by EntityUniqueKey
    if ( collectionType.getLHSPropertyName() != null ) {
      Object owner = getEntity(
          new EntityUniqueKey(
              ownerPersister.getEntityName(),
              collectionType.getLHSPropertyName(),
              key,
              collectionPersister.getKeyType(),
              ownerPersister.getEntityMode(),
              session.getFactory()
          )
      );
      if ( owner != null ) {
        return owner;
      }

      //    b) try by EntityKey, which means we need to resolve owner-key -> collection-key
      //      IMPL NOTE : yes if we get here this impl is very non-performant, but PersistenceContext
      //          was never designed to handle this case; adding that capability for real means splitting
      //          the notions of:
      //            1) collection key
      //            2) collection owner key
      //           these 2 are not always the same (same is true in the case of ToOne associations with
      //           property-ref).  That would require changes to (at least) CollectionEntry and quite
      //          probably changes to how the sql for collection initializers are generated
      //
      //      We could also possibly see if the referenced property is a natural id since we already have caching
      //      in place of natural id snapshots.  BUt really its better to just do it the right way ^^ if we start
      //       going that route
      final Serializable ownerId = ownerPersister.getIdByUniqueKey( key, collectionType.getLHSPropertyName(), session );
      return getEntity( session.generateEntityKey( ownerId, ownerPersister ) );
    }

    // as a last resort this is what the old code did...
    return getEntity( session.generateEntityKey( key, collectionPersister.getOwnerEntityPersister() ) );
View Full Code Here

  }

  private void addAssociationsToTheSetForOneProperty(String name, Type type, String prefix, SessionFactoryImplementor factory) {

    if ( type.isCollectionType() ) {
      CollectionType collType = (CollectionType) type;
      Type assocType = collType.getElementType( factory );
      addAssociationsToTheSetForOneProperty(name, assocType, prefix, factory);
    }
    //ToOne association
    else if ( type.isEntityType() || type.isAnyType() ) {
      associations.add( prefix + name );
View Full Code Here

TOP

Related Classes of org.hibernate.type.CollectionType

Copyright © 2018 www.massapicom. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.