使用带有orientdb的注释自动填充Pojo

时间:2016-01-11 16:18:17

标签: java jpa annotations orientdb

第一点是我正在使用orientdb版本2.1.7。

我尝试用orientdb实现一个包含jpa的项目。如此doc自动加载中所述,保存和删除适用于简单的POJO。

但有两点没有成功。

  1. 我想让酒店与众不同。我知道当我以编程方式执行此操作时它会起作用: OrientVertexType vertexType = graph.createVertexType(vertexName); vertexType.createProperty("id", OType.STRING); vertexType.createIndex("ididx", OClass.INDEX_TYPE.UNIQUE, "id");
  2. 但有没有办法通过注释来做到这一点? JPA注释(@Column(unique = true,nullable = false))似乎不起作用。

    1. 我有两个由Edges连接的VertexType。此外,我希望通过注释自动加载集合。示例(未列出getter和setter): 用户对象:
    2. public class MyUser implements iMyUser { private String id; private String name; private Set<MyGroup> groups; ... }

      群组对象:

      public class MyGroup implements iMyGroup { private String name; private String id; ... }

      在JPA中,您可以向MyUser中的groups属性添加@JoinTable(name = "table", joinColumns = { @JoinColumn(name = "colname") }, inverseJoinColumns = { @JoinColumn(name = "colname") })之类的内容,当您调用方法getGroups()时,您将获得具有关系的组。在orientdb中是否有支持这种行为的注释? 我认为this(@Adjacency)可能是一个解决方案,但直到现在我还没有成功实现它。

      是否还有支持注释的列表或其他内容?

      此致 FOO

1 个答案:

答案 0 :(得分:0)

第二点可能是tinkerpop帧。 @Adjacency注释用于对象之间的直接关系,@ GremlinGroovy用于查询。在界面上有注释有点奇怪,但是它有效。

对于第一点,可能没有通过注释的解决方案,但您可以通过orientdb后端创建唯一索引。