Example usage for org.hibernate.persister.entity AbstractEntityPersister getIdentifierPropertyName

List of usage examples for org.hibernate.persister.entity AbstractEntityPersister getIdentifierPropertyName

Introduction

In this page you can find the example usage for org.hibernate.persister.entity AbstractEntityPersister getIdentifierPropertyName.

Prototype

public String getIdentifierPropertyName() 

Source Link

Usage

From source file:com.aw.core.dao.meta.HbmUtil.java

License:Open Source License

public String getPkFieldName(Class entityClass) {
    //getRealClass(Object entity) sss
    AbstractEntityPersister entityPersister = (AbstractEntityPersister) sessionFactory
            .getClassMetadata(entityClass);
    return entityPersister.getIdentifierPropertyName();
}

From source file:com.aw.core.dao.meta.HbmUtil.java

License:Open Source License

public EntityPropertyMapper buildPropertyMapper(Class entityClass) {
    AbstractEntityPersister entityPersister = (AbstractEntityPersister) sessionFactory
            .getClassMetadata(entityClass);
    if (entityPersister == null)
        throw new IllegalArgumentException("Class " + entityClass + " is not an Hibernate entity class");
    EntityPropertyMapper mapper = new EntityPropertyMapper(entityClass, entityPersister.getTableName());
    String[] propertyNames = entityPersister.getPropertyNames();
    for (String propertyName : propertyNames) {
        String[] columnNames = entityPersister.getPropertyColumnNames(propertyName);
        Type propertyType = entityPersister.getPropertyType(propertyName);
        mapper.put(propertyName, propertyType, columnNames);
    }//from w w w  . j a v  a 2s . c o m
    String identifierPropertyName = entityPersister.getIdentifierPropertyName();
    String[] identifierColumnNames = entityPersister.getIdentifierColumnNames();
    Type identifierPropertyType = entityPersister.getIdentifierType();
    mapper.putId(identifierPropertyName, identifierPropertyType, identifierColumnNames);

    return mapper;
}

From source file:com.aw.core.dao.meta.HbmUtil.java

License:Open Source License

public IdentifierProperty getTableColumnIdentifier(Class entityClass, String entityField) {
    AbstractEntityPersister entityPersister = (AbstractEntityPersister) sessionFactory
            .getClassMetadata(entityClass);
    if (entityField.equalsIgnoreCase(entityPersister.getIdentifierPropertyName()))
        return entityPersister.getEntityMetamodel().getIdentifierProperty();
    else//from  w ww. j  a  va 2  s.c  om
        return null;
}

From source file:com.aw.core.dao.meta.HbmUtil.java

License:Open Source License

public Boolean isUnsaved(Object entity) {
    AbstractEntityPersister entityPersister = (AbstractEntityPersister) sessionFactory
            .getClassMetadata(entity.getClass());
    String identifierPropertyName = entityPersister.getIdentifierPropertyName();
    //IdentifierProperty identifierProperty = entityPersister.getEntityMetamodel().getIdentifierProperty();
    Serializable entityIdValue = (Serializable) new BeanWrapperImpl(entity)
            .getPropertyValue(identifierPropertyName);
    IdentifierValue unSavedValue = entityPersister.getEntityMetamodel().getIdentifierProperty()
            .getUnsavedValue();/*from  w ww.j  av a 2  s  . c o m*/
    return unSavedValue.isUnsaved(entityIdValue);
}

From source file:com.blazebit.persistence.integration.hibernate.base.HibernateJpaProvider.java

License:Apache License

@Override
public Map<String, String> getWritableMappedByMappings(EntityType<?> inverseType, EntityType<?> ownerType,
        String attributeName, String inverseAttribute) {
    AbstractEntityPersister entityPersister = getEntityPersister(ownerType);
    int propertyIndex = entityPersister.getEntityMetamodel().getPropertyIndex(attributeName);
    Type propertyType = entityPersister.getPropertyTypes()[propertyIndex];
    org.hibernate.type.EntityType ownerPropertyType;
    if (propertyType instanceof CollectionType) {
        QueryableCollection persister = getCollectionPersister(ownerType, attributeName);
        AbstractEntityPersister inversePersister = getEntityPersister(inverseType);
        if (!persister.isInverse() && persister.getTableName().equals(inversePersister.getTableName())) {
            // We have a one-to-many relationship that has just join columns

            // Find properties for element columns in entityPersister
            // Map to properties for key columns of inverseType
            Set<String> elementAttributes = getColumnMatchingAttributeNames(entityPersister,
                    Arrays.asList((entityPersister.toColumns(attributeName))));
            Set<String> keyAttributes = removeIdentifierAccess(ownerType, elementAttributes, inverseType,
                    getColumnMatchingAttributeNames(inversePersister,
                            Arrays.asList(persister.getKeyColumnNames())));

            Map<String, String> mapping = new HashMap<>();
            Iterator<String> elemAttrIter = elementAttributes.iterator();
            Iterator<String> keyAttrIter = keyAttributes.iterator();

            while (elemAttrIter.hasNext()) {
                mapping.put(elemAttrIter.next(), keyAttrIter.next());
            }//from  w  w w .j  a va  2  s .co  m

            if (mapping.isEmpty()) {
                throw new IllegalArgumentException("Mapped by property '" + inverseType.getName() + "#"
                        + attributeName + "' must be writable or the column must be part of the id!");
            }
            return mapping;
        } else {
            // We only support detection when the inverse collection is writable
            if (entityPersister.getEntityMetamodel().getPropertyInsertability()[propertyIndex]) {
                return null;
            }
            throw new IllegalArgumentException("Mapped by property '" + inverseType.getName() + "#"
                    + attributeName + "' must be writable!");
        }
    } else {
        // Either the mapped by property is writable
        if (entityPersister.getEntityMetamodel().getPropertyInsertability()[propertyIndex]) {
            return null;
        }
        // Or the columns of the mapped by property are part of the target id
        ownerPropertyType = (org.hibernate.type.EntityType) propertyType;
    }
    AbstractEntityPersister sourceType = (AbstractEntityPersister) entityPersisters
            .get(ownerPropertyType.getAssociatedEntityName());
    Type identifierType = ownerPropertyType.getIdentifierOrUniqueKeyType(entityPersister.getFactory());
    String sourcePropertyPrefix;
    String[] sourcePropertyNames;
    if (identifierType.isComponentType()) {
        ComponentType componentType = (ComponentType) identifierType;
        sourcePropertyPrefix = sourceType.getIdentifierPropertyName() + ".";
        sourcePropertyNames = componentType.getPropertyNames();
    } else {
        sourcePropertyPrefix = "";
        sourcePropertyNames = new String[] { sourceType.getIdentifierPropertyName() };
    }
    String[] targetColumnNames = entityPersister.getPropertyColumnNames(propertyIndex);
    Type targetIdType = entityPersister.getIdentifierType();
    if (targetIdType.isComponentType()) {
        ComponentType targetIdentifierType = (ComponentType) entityPersister.getIdentifierType();
        String targetPropertyPrefix = entityPersister.getIdentifierPropertyName() + ".";
        String[] identifierColumnNames = entityPersister.getIdentifierColumnNames();
        String[] targetIdentifierTypePropertyNames = targetIdentifierType.getPropertyNames();
        Map<String, String> mapping = new HashMap<>();
        for (int i = 0; i < targetColumnNames.length; i++) {
            for (int j = 0; j < identifierColumnNames.length; j++) {
                if (targetColumnNames[i].equals(identifierColumnNames[j])) {
                    mapping.put(sourcePropertyPrefix + sourcePropertyNames[i],
                            targetPropertyPrefix + targetIdentifierTypePropertyNames[j]);
                    break;
                }
            }
        }
        if (mapping.isEmpty()) {
            throw new IllegalArgumentException("Mapped by property '" + inverseType.getName() + "#"
                    + attributeName + "' must be writable or the column must be part of the id!");
        }
        return mapping;
    } else {
        String targetIdColumnName = entityPersister.getIdentifierColumnNames()[0];
        if (!targetIdColumnName.equals(targetColumnNames[0])) {
            throw new IllegalArgumentException("Mapped by property '" + inverseType.getName() + "#"
                    + attributeName + "' must be writable or the column must be part of the id!");
        }
        Map<String, String> mapping = new HashMap<>();
        mapping.put(sourcePropertyPrefix + sourcePropertyNames[0], entityPersister.getIdentifierPropertyName());
        return mapping;
    }
}

From source file:com.blazebit.persistence.integration.hibernate.base.HibernateJpaProvider.java

License:Apache License

private static Set<String> getColumnMatchingAttributeNames(AbstractEntityPersister ownerEntityPersister,
        List<String> idColumnNames) {
    Set<String> idAttributeNames = new LinkedHashSet<>();
    Type identifierType = ownerEntityPersister.getIdentifierType();
    if (identifierType instanceof ComponentType) {
        String[] idPropertyNames = ((ComponentType) identifierType).getPropertyNames();
        for (String propertyName : idPropertyNames) {
            String attributeName = ownerEntityPersister.getIdentifierPropertyName() + "." + propertyName;
            String[] propertyColumnNames = ownerEntityPersister.getSubclassPropertyColumnNames(attributeName);
            if (propertyColumnNames != null) {
                for (int j = 0; j < propertyColumnNames.length; j++) {
                    String propertyColumnName = propertyColumnNames[j];
                    if (idColumnNames.contains(propertyColumnName)) {
                        idAttributeNames.add(attributeName);
                        break;
                    }// w w w  . ja v a  2  s . co  m
                }
            }
        }
        // We assume that when a primary identifier attribute is part of the id column names, that we are done
        if (!idAttributeNames.isEmpty()) {
            return idAttributeNames;
        }
    } else {
        for (String identifierColumnName : ownerEntityPersister.getIdentifierColumnNames()) {
            if (idColumnNames.contains(identifierColumnName)) {
                idAttributeNames.add(ownerEntityPersister.getIdentifierPropertyName());
                return idAttributeNames;
            }
        }
    }
    String[] propertyNames = ownerEntityPersister.getPropertyNames();
    for (int i = 0; i < propertyNames.length; i++) {
        String propertyName = propertyNames[i];
        String[] propertyColumnNames = ownerEntityPersister.getSubclassPropertyColumnNames(propertyName);
        if (propertyColumnNames != null) {
            for (int j = 0; j < propertyColumnNames.length; j++) {
                String propertyColumnName = propertyColumnNames[j];
                if (idColumnNames.contains(propertyColumnName)) {
                    idAttributeNames.add(propertyName);
                    break;
                }
            }
        }
    }
    return idAttributeNames;
}

From source file:gov.nih.nci.security.upt.util.HibernateHelper.java

License:BSD License

private static String modifySQLForUser(FilterClause filterClause, String generatedSQL, Session session,
        String peiTableOrViewName) {
    String targetClassName = null;
    if (StringUtils.isBlank(filterClause.getTargetClassAlias()))
        targetClassName = filterClause.getTargetClassName().substring(0,
                filterClause.getTargetClassName().indexOf(" - "));
    else//w w  w  .  j a  va 2  s . c o m
        targetClassName = filterClause.getTargetClassAlias();
    String targetClassAttributeName = null;
    if (StringUtils.isBlank(filterClause.getTargetClassAttributeAlias()))
        targetClassAttributeName = filterClause.getTargetClassAttributeName();
    else
        targetClassAttributeName = filterClause.getTargetClassAttributeAlias();

    String CSM_QUERY = " select pe.attribute_value from " + "csm_protection_group pg, "
            + "csm_protection_element pe, " + "csm_pg_pe pgpe, " + "csm_user_group_role_pg ugrpg, "
            + "csm_user u, " + "csm_role_privilege rp, " + "csm_role r, " + "csm_privilege p "
            + "where ugrpg.role_id = r.role_id " + "and ugrpg.user_id = u.user_id and "
            + "ugrpg.protection_group_id = ANY " + "(select pg1.protection_group_id "
            + "from csm_protection_group pg1 " + "where pg1.protection_group_id = pg.protection_group_id "
            + "or pg1.protection_group_id = " + "(select pg2.parent_protection_group_id "
            + "from csm_protection_group pg2 " + "where pg2.protection_group_id = pg.protection_group_id)) "
            + "and pg.protection_group_id = pgpe.protection_group_id "
            + "and pgpe.protection_element_id = pe.protection_element_id " + "and r.role_id = rp.role_id "
            + "and rp.privilege_id = p.privilege_id " + "and pe.object_id= '" + targetClassName + "' "
            + "and pe.attribute='" + targetClassAttributeName + "' " + "and p.privilege_name='READ' "
            + "and u.login_name=:USER_NAME " + "and pe.application_id=:APPLICATION_ID";

    String CSM_QUERY_2 = "select upei.attribute_value from " + peiTableOrViewName + " upei where "
            + "upei.login_name=:USER_NAME and upei.application_id =:APPLICATION_ID and upei.privilege_name='READ'";

    StringBuffer result = new StringBuffer();
    String query = generatedSQL.substring(generatedSQL.indexOf('-') + 1, generatedSQL.length());
    query = query.trim();
    query = query.substring(0, query.indexOf('?'));
    String delimiters = "+-*/(),. ";
    StringTokenizer st = new StringTokenizer(query, delimiters, true);
    while (st.hasMoreTokens()) {
        String w = st.nextToken();
        if (w.equals("this_")) {
            result = result.append("table_name_csm_");
        } else if (w.equals("y0_")) {
            result = result.append("");
        } else if (w.equals("as")) {
            result = result.append("");
        } else {
            result = result.append(w);
        }
    }
    SessionFactory sessionFactory = session.getSessionFactory();
    ClassMetadata classMetadata = sessionFactory.getClassMetadata(filterClause.getClassName());
    String columnName = null;
    if (classMetadata instanceof AbstractEntityPersister) {
        AbstractEntityPersister abstractEntityPersister = (AbstractEntityPersister) classMetadata;
        String Id = abstractEntityPersister.getIdentifierPropertyName();
        String[] columns = abstractEntityPersister.getPropertyColumnNames(Id);
        columnName = columns[0];
    }
    if (!StringUtils.isBlank(peiTableOrViewName)) {
        query = columnName + " in (" + result.toString() + CSM_QUERY_2 + "))";
    } else {
        query = columnName + " in (" + result.toString() + CSM_QUERY + "))";
    }

    return query.toString();
}

From source file:gov.nih.nci.security.upt.util.HibernateHelper.java

License:BSD License

private static String modifySQLForGroup(FilterClause filterClause, String generatedSQL, Session session,
        String peiTableOrViewName) {
    String targetClassName = null;
    if (StringUtils.isBlank(filterClause.getTargetClassAlias()))
        targetClassName = filterClause.getTargetClassName().substring(0,
                filterClause.getTargetClassName().indexOf(" - "));
    else//from www  .j a va2 s.  co  m
        targetClassName = filterClause.getTargetClassAlias();
    String targetClassAttributeName = null;
    if (StringUtils.isBlank(filterClause.getTargetClassAttributeAlias()))
        targetClassAttributeName = filterClause.getTargetClassAttributeName();
    else
        targetClassAttributeName = filterClause.getTargetClassAttributeAlias();

    String CSM_QUERY = "SELECT Distinct pe.attribute_value " + "FROM CSM_PROTECTION_GROUP pg, "
            + "   CSM_PROTECTION_ELEMENT pe, " + "   CSM_PG_PE pgpe," + "   CSM_USER_GROUP_ROLE_PG ugrpg, "
            + "   CSM_GROUP g, " + "   CSM_ROLE_PRIVILEGE rp, " + "   CSM_ROLE r, " + "   CSM_PRIVILEGE p "
            + "WHERE ugrpg.role_id = r.role_id " + "AND ugrpg.group_id = g.group_id "
            + "AND ugrpg.protection_group_id = ANY "
            + "( select pg1.protection_group_id from csm_protection_group pg1 "
            + " where pg1.protection_group_id = pg.protection_group_id OR pg1.protection_group_id = "
            + " (select pg2.parent_protection_group_id from csm_protection_group pg2 where pg2.protection_group_id = pg.protection_group_id)"
            + " ) " + "AND pg.protection_group_id = pgpe.protection_group_id "
            + "AND pgpe.protection_element_id = pe.protection_element_id " + "AND r.role_id = rp.role_id "
            + "AND rp.privilege_id = p.privilege_id " + "AND pe.object_id= '" + targetClassName + "' "
            + "AND p.privilege_name='READ' " + "AND g.group_name IN (:GROUP_NAMES ) "
            + "AND pe.application_id=:APPLICATION_ID";

    String CSM_QUERY_2 = "select upei.attribute_value from " + peiTableOrViewName + " upei where "
            + "upei.group_name IN (:GROUP_NAMES) and upei.application_id =:APPLICATION_ID and upei.privilege_name='READ'";

    /*String CSM_QUERY = " select pe.attribute_value from " +
    "csm_protection_group pg, " +
    "csm_protection_element pe, " +
    "csm_pg_pe pgpe, " +
    "csm_user_group_role_pg ugrpg, " +
    "csm_user u, " +
    "csm_role_privilege rp, " +
    "csm_role r, " +
    "csm_privilege p " +
    "where ugrpg.role_id = r.role_id " +
    "and ugrpg.user_id = u.user_id and " +
    "ugrpg.protection_group_id = ANY " +
    "(select pg1.protection_group_id " +
    "from csm_protection_group pg1 " +
    "where pg1.protection_group_id = pg.protection_group_id " +
    "or pg1.protection_group_id = " +
    "(select pg2.parent_protection_group_id " +
    "from csm_protection_group pg2 " +
    "where pg2.protection_group_id = pg.protection_group_id)) " +
    "and pg.protection_group_id = pgpe.protection_group_id " +
    "and pgpe.protection_element_id = pe.protection_element_id " +
    "and r.role_id = rp.role_id " +
    "and rp.privilege_id = p.privilege_id " +
    "and pe.object_id= '" + targetClassName + "' " +
    "and pe.attribute='" + targetClassAttributeName + "' " +
    "and p.privilege_name='READ' "  +
    "and u.login_name=:USER_NAME " +
    "and pe.application_id=:APPLICATION_ID" ; */

    StringBuffer result = new StringBuffer();
    String query = generatedSQL.substring(generatedSQL.indexOf('-') + 1, generatedSQL.length());
    query = query.trim();
    query = query.substring(0, query.indexOf('?'));
    String delimiters = "+-*/(),. ";
    StringTokenizer st = new StringTokenizer(query, delimiters, true);
    while (st.hasMoreTokens()) {
        String w = st.nextToken();
        if (w.equals("this_")) {
            result = result.append("table_name_csm_");
        } else if (w.equals("y0_")) {
            result = result.append("");
        } else if (w.equals("as")) {
            result = result.append("");
        } else {
            result = result.append(w);
        }
    }
    SessionFactory sessionFactory = session.getSessionFactory();
    ClassMetadata classMetadata = sessionFactory.getClassMetadata(filterClause.getClassName());
    String columnName = null;
    if (classMetadata instanceof AbstractEntityPersister) {
        AbstractEntityPersister abstractEntityPersister = (AbstractEntityPersister) classMetadata;
        String Id = abstractEntityPersister.getIdentifierPropertyName();
        String[] columns = abstractEntityPersister.getPropertyColumnNames(Id);
        columnName = columns[0];
    }
    if (!StringUtils.isBlank(peiTableOrViewName)) {
        query = columnName + " in (" + result.toString() + CSM_QUERY_2 + "))";
    } else {
        query = columnName + " in (" + result.toString() + CSM_QUERY + "))";
    }

    return query.toString();
}

From source file:org.nextframework.persistence.PersistenceUtils.java

License:Apache License

public static InverseCollectionProperties getInverseCollectionProperty(SessionFactory sessionFactory,
        Class<? extends Object> clazz, String collectionProperty) {
    SessionFactoryImplementor sessionFactoryImplementor;
    String[] keyColumnNames;/*  ww w . j a va 2s .  co m*/
    Class<?> returnedClass;
    try {
        sessionFactoryImplementor = (SessionFactoryImplementor) sessionFactory;
        ClassMetadata classMetadata = getClassMetadata(clazz, sessionFactory);
        if (classMetadata == null) {
            throw new PersistenceException("Class " + clazz.getName() + " is not mapped. ");
        }
        CollectionType ct = (CollectionType) classMetadata.getPropertyType(collectionProperty);
        AbstractCollectionPersister collectionMetadata = (AbstractCollectionPersister) sessionFactoryImplementor
                .getCollectionMetadata(ct.getRole());
        keyColumnNames = ((AbstractCollectionPersister) collectionMetadata).getKeyColumnNames();
        returnedClass = ct.getElementType(sessionFactoryImplementor).getReturnedClass();
    } catch (ClassCastException e) {
        throw new PersistenceException(
                "Property \"" + collectionProperty + "\" of " + clazz + " is not a mapped as a collection.");
    }

    AbstractEntityPersister collectionItemMetadata = (AbstractEntityPersister) sessionFactoryImplementor
            .getClassMetadata(returnedClass);
    Type[] propertyTypes = collectionItemMetadata.getPropertyTypes();
    String[] propertyNames = collectionItemMetadata.getPropertyNames();
    for (int i = 0; i < propertyTypes.length; i++) {
        Type type = propertyTypes[i];
        String propertyName = propertyNames[i];
        String[] propertyColumnNames = collectionItemMetadata.getPropertyColumnNames(propertyName);
        InverseCollectionProperties inverseCollectionProperties = getInverseCollectionProperties(
                sessionFactoryImplementor, clazz, returnedClass, keyColumnNames, propertyColumnNames, type,
                propertyName);
        if (inverseCollectionProperties != null) {
            return inverseCollectionProperties;
        }
    }
    //check id
    Type identifierType = collectionItemMetadata.getIdentifierType();
    String identifierName = collectionItemMetadata.getIdentifierPropertyName();
    String[] identifierColumnNames = collectionItemMetadata.getIdentifierColumnNames();
    InverseCollectionProperties inverseCollectionProperties = getInverseCollectionProperties(
            sessionFactoryImplementor, clazz, returnedClass, keyColumnNames, identifierColumnNames,
            identifierType, identifierName);
    if (inverseCollectionProperties != null) {
        return inverseCollectionProperties;
    }
    throw new PersistenceException(
            "Collection " + collectionProperty + " of " + clazz + " does not have an inverse path!");
}

From source file:to.etc.domui.hibernate.model.CriteriaCreatingVisitor.java

License:Open Source License

/**
 * Hibernate's jokish metadata does not include the PK in it's properties structures. So
 * we explicitly need to check if the name is the PK property, then return the column names
 * for that PK./*  w w w . ja  v a  2 s .  c  om*/
 *
 * @param aep
 * @param compoundName
 * @return
 */
@NonNull
private String[] getPropertyColumnNamesFromLousyMetadata(AbstractEntityPersister aep, String compoundName) {
    String name = compoundName;
    int dotix = compoundName.lastIndexOf('.');
    if (dotix != -1) {
        name = compoundName.substring(dotix + 1);
    }

    //-- The PK property is not part of the "properties" in hibernate's idiot metadata. So first check if we're looking at that ID property.
    if (name.equals(aep.getIdentifierPropertyName())) {
        return aep.getIdentifierColumnNames();
    }
    int ix = aep.getPropertyIndex(name);
    if (ix < 0)
        throw new QQuerySyntaxException(
                "Cannot obtain Hibernate metadata for property=" + name + ": property index not found");
    String[] colar = aep.getPropertyColumnNames(ix);
    if (colar == null || colar.length != 1/* || colar[0] == null*/)
        throw new QQuerySyntaxException("'Like' cannot be done on multicolumn/0column property " + name);
    return colar;
}