Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Multi-Properties #120

Open
flaviocordova opened this issue Feb 25, 2017 · 5 comments
Open

Multi-Properties #120

flaviocordova opened this issue Feb 25, 2017 · 5 comments
Assignees

Comments

@flaviocordova
Copy link

Tinkerpop Documentation says a property may have more than one value (http://tinkerpop.apache.org/docs/current/reference/#vertex-properties).

Just as an example: this works on gremlin console:

graph = TinkerGraph.open();
g = graph.traversal();
v = graph.addVertex("User");
v.property("name", "New with list prop");
v.property(list, "prop1", "value 1");
v.property(list, "prop1", "value 2");
g.V().has("prop1", "value 1").has("prop1", "value 2").values("name")

When using orientdb-gremlin it will override "value1" and keep only the last value, invalidating the query.

I tried using v.property("prop1", Arrays.asList("value1", "value2")) and indeed it saved the values in the database, but then you can't query using only one of the values.

@velo
Copy link
Contributor

velo commented Feb 25, 2017

Well, not all tinkerpop features are compatible with orient.

This is one of them.

Take vanilla OrientDB. Set a property. Set it again. It just overrides. Like a java map

@flaviocordova
Copy link
Author

flaviocordova commented Feb 25, 2017

Not exactly... OrientDB supports what it call "embedded list" and embedded set that match with both Cardinality.set and Cardinality.list. Couldn't the gremlin layer just select the suitable type according the the propertiy's cardinality ? It seems to make sense....

Once this working property, the has step (has(prop, value)) could just check see the field type to adapt the query. The query bellow works fine in OrientDB Studio and it looks pretty much to the same.

select * from V_User where prop3 contains 'value1' and prop3 contains 'value 2'

I understand there must be much more underneath then just data types and sql, but it doesn't seems to be impossible and it look much more elegant than Neo4j's driver approach (to create hidden vertices to store the values).

@flaviocordova
Copy link
Author

I haven't tested but according to the documentation, embedded list/set fields can be even indexed:

orientdb> CREATE PROPERTY Book.author STRING
orientdb> CREATE PROPERTY Book.title STRING
orientdb> CREATE PROPERTY Book.publicationYears EMBEDDEDLIST INTEGER
orientdb> CREATE INDEX books ON Book (author, title, publicationYears) UNIQUE

@velo
Copy link
Contributor

velo commented Feb 26, 2017 via email

@flaviocordova
Copy link
Author

Well, IMHO the proper way to set the property is using the Cardinality parameter to make explicit which behavior is expected. When cardinality is not specified, I don't see any problem if the provider choose whatever approach it want.

In other words, it's ok to replace as long as there's a way to aggregate.

@wolf4ood wolf4ood self-assigned this Aug 7, 2017
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants