我需要获得两个模型类之间的关系。 例如 在数据库中,我有两个表table1和table2。其中table2具有table1的外键。 我有两个类Table1和Table2分别映射到这些表,并具有映射One到One的关系。
现在,从java代码我需要检索它们有什么关系?即上例中的输出应该是一对一的。
答案 0 :(得分:2)
我准备了这个演示来查找两个hibernate实体类之间的关联类型。它可以帮助其他社区用户发布此答案。
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.Map;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
import org.hibernate.metadata.ClassMetadata;
import org.hibernate.metadata.CollectionMetadata;
import org.hibernate.persister.collection.BasicCollectionPersister;
import org.hibernate.persister.collection.OneToManyPersister;
import org.hibernate.service.ServiceRegistryBuilder;
import org.hibernate.type.ManyToOneType;
import org.hibernate.type.OneToOneType;
import org.hibernate.type.Type;
/**
*
* @author shruti
*/
public class RelationDemo {
public static void main(String[] args) throws Exception {
Configuration configuration = new Configuration().configure();
ServiceRegistryBuilder builder = new ServiceRegistryBuilder().applySettings(configuration.getProperties());
SessionFactory sessionfactory = configuration.buildSessionFactory(builder.buildServiceRegistry());
//1. Read class names
System.out.println("Enter first class names (make sure you enter fully qualified name): ");
BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(System.in));
String class1 = bufferedReader.readLine();
System.out.println("Enter second class names (make sure you enter fully qualified name): ");
String class2 = bufferedReader.readLine();
ClassMetadata classMetadata = null;
//2. Create ClassMetaData for the first class name and check that both the classes exists.
try {
classMetadata = sessionfactory.getClassMetadata(Class.forName(class1));
Class.forName(class2);
} catch (ClassNotFoundException classNotFoundException) {
System.err.println("Invalid class name.\nHint: Enter fully qualified class names for eg. packagename.Classname");
classNotFoundException.printStackTrace(System.err);
return;
}
//3. Retrieve all collection metada for collection type properties
@SuppressWarnings("unchecked")
Map<String, CollectionMetadata> allCollectionMetadata = sessionfactory.getAllCollectionMetadata();
//Retrieve all properties of the first class
String[] propertyNames = classMetadata.getPropertyNames();
//Loop through the retrieved properties
for (String name : propertyNames) {
//Retrieve type of each property
Type type = classMetadata.getPropertyType(name.trim());
//Check if the type is association type
if (type.isAssociationType()) {
//Check if it is collection type.
if (type.isCollectionType()) {
//From retrieved collection metadata (Strp 3) get value of the property we are refering to.
CollectionMetadata collectionMetadata = allCollectionMetadata.get(class1 + "." + name);
//Check if the elements of the collection are of desiered type
if (collectionMetadata.getElementType().getName().trim().equals(class2)) {
System.out.println("Property Name: " + name);
//Check if the value is of type OneToManyPersister
if (collectionMetadata instanceof OneToManyPersister) {
System.out.println("ONE TO MANY TYPE");
return;
} //Check if the value is of type BasicCollectionPersister. Note that for many to many relationship it would return an object of type BasicCollectionPersister.
else if (collectionMetadata instanceof BasicCollectionPersister) {
if (((BasicCollectionPersister) collectionMetadata).isManyToMany()) {
System.out.println("MANY TO MANY");
}
}
}
} //If property is not a collection then retrieve the class of the type and check if it is the same as Second class.
else if (type.getReturnedClass().getTypeName().equals(class2)) {
System.out.println("Property Name: " + name);
if (type instanceof ManyToOneType) {
System.out.println("MANY TO ONE TYPE");
return;
} else if (type instanceof OneToOneType) {
System.out.println("ONE TO ONE TYPE");
return;
}
}
}
}
System.out.println("NO RELATIONSHIP FOUND BETWEEN GIVEN CLASSES");
}
}
答案 1 :(得分:0)
Hibernate有元数据包org.hibernate.metadta,它可以帮到你。 请参阅 https://docs.jboss.org/hibernate/orm/3.5/api/org/hibernate/metadata/ClassMetadata.html
答案 2 :(得分:0)
您可以尝试使用以下代码来显示实体可用的集合详细信息:
Map<String,CollectionMetadata> map = sessionFactory.getAllCollectionMetadata();
Set<Entry<String,CollectionMetadata>> set = map.entrySet();
for (Entry e : set) {
System.out.println(e.getKey());
System.out.println(e.getValue());
}