London, December 20th 2013
OrientDB Team is working on SQL language to provide more powerful functions to works against types. Since OrientDB can work in schema-less mode, it's hard to know the real type of a value. For example when you work with numbers, you could have different type stored. How to know if a number is a Long or an Integer?
select roles.type() from ouser
select roles.javaType() from ouser
select roles.convert(STRING) from ouser
select roles.convert(java.lang.String) from ouser
Since the type is an EMBEDDEDSET, the more interesting thing is converting into a list to get the first value. Example:
OrientDB Team is working on SQL language to provide more powerful functions to works against types. Since OrientDB can work in schema-less mode, it's hard to know the real type of a value. For example when you work with numbers, you could have different type stored. How to know if a number is a Long or an Integer?
.type() method (since 2.0)
Here comes the new type() method (all these methods are available on 2.0-SNAPSHOT, "develop" branch), that returns the OrientDB type of a value. Let's try it against the ROLES property of OUser class.select roles.type() from ouser
@rid | @version | roles |
---|---|---|
#-2:1 | 0 | LINKSET |
It's an LINKSET!
NOTE: .type() method works on the SQL pipeline, so it doesn't access to the stored type, but the type loaded in memory and in case of SET, LIST and MAP sometimes can't distinguish between EMBEDDED types and LINK types.
.javaType() method (since 2.0)
When you want to know the respective Java class, you can use the method .javaType(), example:
@rid | @version | roles |
---|---|---|
#-2:1 | 0 | com.orientechnologies.orient.core.type.tree.OMVRBTreeRIDSet |
Now we can access to the type it would be cool to convert values at the fly. OrientDB already has few methods to to this:
- asBoolean()
- asDate()
- asDateTime()
- asDecimal()
- asFloat()
- asInteger()
- asList()
- asLong()
- asSet()
- asString()
But we've implemented a generic convert(<type>) method to convert values dynamically.
.convert(<type>) method (since 2.0)
convert() accepts as unique, mandatory, parameter the OrientDB type (OType enumeration) or any Java type recognized by OrientDB. Example using the STRING OrientDB type:
@rid | @version | roles |
---|---|---|
#-2:1 | 0 | [#4:0=#4:0] |
And the same using the Java type:
select roles.convert(java.lang.String) from ouser
@rid | @version | roles |
---|---|---|
#-2:1 | 0 | [#4:0=#4:0] |
select roles.convert(EMBEDDEDLIST)[0] from ouser
No comments:
Post a Comment
Note: only a member of this blog may post a comment.