List of usage examples for org.hibernate.persister.entity AbstractEntityPersister getIdentifierPropertyName
public String getIdentifierPropertyName()
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; }