Home » Modeling » EMF » [CDO] DBStore support for join and async query
| |
Re: [CDO] DBStore support for join and async query [message #1226644 is a reply to message #1226315] |
Thu, 02 January 2014 09:44 |
Ashish Shinde Messages: 21 Registered: August 2013 |
Junior Member |
|
|
Hi Erdal,
Yes the DBStore executes the join SQL query by delegating it to the backend, however the problem I am facing is that the SQLQueryHandler returns, only the first object for each query result instead of all components of the join.
e.g. for the query select table1.*, table2.* from table1,table2 , the result one would get from the db would be the
table1_object1 (as columns), table2_object1 (as columns)
table1_object2 (as columns), table2_object2 (as columns)
table1_object3 (as columns), table2_object3 (as columns)
however the dbstore query returns
table1_object1,
table1_object2,
table1_object3
ignoring all objects from table2.
Hence the question is does/will dbstore support join queries where the exact join result is returned to the caller instead of only objects from first table in the join.
Thanks and regards,
- Ashish
Erdal Karaca wrote on Wed, 01 January 2014 05:55The DBStore executes the SQL statement by delegating to the underlying backend.
This is comparable to Hibernate's/JPA's native queries.
CDO generates the tables such that they are unique, for example, for an EClass mypackage.A, the table name may be mypackage_ns_uri_A (where mypackage_ns_uri = the EPackage's namespace URI prefix).
The best (at the moment) is to have a look at the database table names that are generated.
Ashish Shinde wrote on Wed, 01 January 2014 07:44Hi,
We are using CDO with DBStore for our project.
The sql handler for DBStore looked to not handle join queries. As in the first object from the join result was returned back.
Does dbstore support joins? If so how do I formulate queries to return join results. If not is there some work in progress in this regard. [ Hibernate store looked to support joins but the lack of support for branching and hql queries on audit data made us chose db store].
A slightly off track question relating to dbstore is, for sql queries if two different packages have the same name for an eclass how would one formulate a sql query using this eclass.
Thanks,
Ashish
|
|
|
Re: [CDO] DBStore support for join and async query [message #1226663 is a reply to message #1226644] |
Thu, 02 January 2014 10:40 |
Christophe Bouhier Messages: 937 Registered: July 2009 |
Senior Member |
|
|
On 02-01-14 10:44, Ashish Shinde wrote:
> Hi Erdal,
>
> Yes the DBStore executes the join SQL query by delegating it to the
> backend, however the problem I am facing is that the SQLQueryHandler
> returns, only the first object for each query result instead of all
> components of the join.
>
> e.g. for the query select table1.*, table2.* from table1,table2 , the
> result one would get from the db would be the
> table1_object1 (as columns), table2_object1 (as columns)
> table1_object2 (as columns), table2_object2 (as columns)
> table1_object3 (as columns), table2_object3 (as columns)
>
> however the dbstore query returns table1_object1,
> table1_object2, table1_object3
Hi Ashish,
I can't provide you the answer, but I think the SQL handler for CDO will
comply to a subset of vendor SQL, which is therefor always a compromise.
(As the DBStore supports many types of DB's and not all dialects will be
supported.)
Do you know if the syntax (separating tables with comma, and using wild
card) is something you might be accustomed to from a certain DB vendor
(Which ones is it?). So is the query you run SQL compliant?
http://en.wikipedia.org/wiki/SQL#Standardization
BTW, have you tried with the actual 'join' keyword and telling which
columns should be joined? (CDO ID is alway a good joiner :-)
Cheers Christophe
>
> ignoring all objects from table2.
> Hence the question is does/will dbstore support join queries where the
> exact join result is returned to the caller instead of only objects from
> first table in the join.
>
> Thanks and regards,
> - Ashish
>
> Erdal Karaca wrote on Wed, 01 January 2014 05:55
>> The DBStore executes the SQL statement by delegating to the underlying
>> backend.
>> This is comparable to Hibernate's/JPA's native queries.
>>
>> CDO generates the tables such that they are unique, for example, for
>> an EClass mypackage.A, the table name may be mypackage_ns_uri_A (where
>> mypackage_ns_uri = the EPackage's namespace URI prefix).
>> The best (at the moment) is to have a look at the database table names
>> that are generated.
>>
>> Ashish Shinde wrote on Wed, 01 January 2014 07:44
>> > Hi,
>> > > We are using CDO with DBStore for our project. > > The sql handler
>> for DBStore looked to not handle join queries. As in the first object
>> from the join result was returned back. > > Does dbstore support
>> joins? If so how do I formulate queries to return join results. If not
>> is there some work in progress in this regard. [ Hibernate store
>> looked to support joins but the lack of support for branching and hql
>> queries on audit data made us chose db store].
>> > > A slightly off track question relating to dbstore is, for sql
>> queries if two different packages have the same name for an eclass how
>> would one formulate a sql query using this eclass.
>> > > Thanks,
>> > Ashish
>
>
|
|
|
Re: [CDO] DBStore support for join and async query [message #1226676 is a reply to message #1226644] |
Thu, 02 January 2014 11:16 |
Erdal Karaca Messages: 854 Registered: July 2009 |
Senior Member |
|
|
The SQL handler only checks the first column if the query is an "object query" (which is the default if you have not set that paramter).
I guess you have to file an enhancement request.
Ashish Shinde wrote on Thu, 02 January 2014 10:44Hi Erdal,
Yes the DBStore executes the join SQL query by delegating it to the backend, however the problem I am facing is that the SQLQueryHandler returns, only the first object for each query result instead of all components of the join.
e.g. for the query select table1.*, table2.* from table1,table2 , the result one would get from the db would be the
table1_object1 (as columns), table2_object1 (as columns)
table1_object2 (as columns), table2_object2 (as columns)
table1_object3 (as columns), table2_object3 (as columns)
however the dbstore query returns
table1_object1,
table1_object2,
table1_object3
ignoring all objects from table2.
Hence the question is does/will dbstore support join queries where the exact join result is returned to the caller instead of only objects from first table in the join.
Thanks and regards,
- Ashish
Erdal Karaca wrote on Wed, 01 January 2014 05:55The DBStore executes the SQL statement by delegating to the underlying backend.
This is comparable to Hibernate's/JPA's native queries.
CDO generates the tables such that they are unique, for example, for an EClass mypackage.A, the table name may be mypackage_ns_uri_A (where mypackage_ns_uri = the EPackage's namespace URI prefix).
The best (at the moment) is to have a look at the database table names that are generated.
Ashish Shinde wrote on Wed, 01 January 2014 07:44Hi,
We are using CDO with DBStore for our project.
The sql handler for DBStore looked to not handle join queries. As in the first object from the join result was returned back.
Does dbstore support joins? If so how do I formulate queries to return join results. If not is there some work in progress in this regard. [ Hibernate store looked to support joins but the lack of support for branching and hql queries on audit data made us chose db store].
A slightly off track question relating to dbstore is, for sql queries if two different packages have the same name for an eclass how would one formulate a sql query using this eclass.
Thanks,
Ashish
|
|
|
Re: [CDO] DBStore support for join and async query [message #1226973 is a reply to message #1226676] |
Fri, 03 January 2014 07:41 |
|
Am 02.01.2014 12:16, schrieb Erdal Karaca:
> The SQL handler only checks the first column if the query is an "object query" (which is the default if you have not
> set that paramter).
> I guess you have to file an enhancement request.
You can explicitely tell the SQLQueryHandler to return all column values (instead of using the first column to identify
a CDOObject):
CDOQuery query = transaction.createQuery("sql", "SELECT street, city, name FROM model1_customer ORDER BY street");
*query.setParameter("cdoObjectQuery", false);*
List<Object[]> results = query.getResult(Object[].class);
Or return each row as a map:
CDOQuery query = transaction.createQuery("sql", "SELECT street, city, name FROM model1_customer ORDER BY street");
query.setParameter("cdoObjectQuery", false);
*query.setParameter("mapQuery", true);*
List<Map<String, Object>> results = query.getResult();
Cheers
/Eike
----
http://www.esc-net.de
http://thegordian.blogspot.com
http://twitter.com/eikestepper
>
> Ashish Shinde wrote on Thu, 02 January 2014 10:44
>> Hi Erdal,
>>
>> Yes the DBStore executes the join SQL query by delegating it to the backend, however the problem I am facing is that
>> the SQLQueryHandler returns, only the first object for each query result instead of all components of the join.
>>
>> e.g. for the query select table1.*, table2.* from table1,table2 , the result one would get from the db would be the
>> table1_object1 (as columns), table2_object1 (as columns)
>> table1_object2 (as columns), table2_object2 (as columns)
>> table1_object3 (as columns), table2_object3 (as columns)
>>
>> however the dbstore query returns table1_object1,
>> table1_object2, table1_object3
>>
>> ignoring all objects from table2.
>> Hence the question is does/will dbstore support join queries where the exact join result is returned to the caller
>> instead of only objects from first table in the join.
>>
>> Thanks and regards,
>> - Ashish
>>
>> Erdal Karaca wrote on Wed, 01 January 2014 05:55
>> > The DBStore executes the SQL statement by delegating to the underlying backend.
>> > This is comparable to Hibernate's/JPA's native queries.
>> > > CDO generates the tables such that they are unique, for example, for an EClass mypackage.A, the table name may be
>> mypackage_ns_uri_A (where mypackage_ns_uri = the EPackage's namespace URI prefix).
>> > The best (at the moment) is to have a look at the database table names that are generated.
>> > > Ashish Shinde wrote on Wed, 01 January 2014 07:44
>> > > Hi,
>> > > > > We are using CDO with DBStore for our project. > > > > The sql handler for DBStore looked to not handle join
>> queries. As in the first object from the join result was returned back. > > > > Does dbstore support joins? If so how
>> do I formulate queries to return join results. If not is there some work in progress in this regard. [ Hibernate
>> store looked to support joins but the lack of support for branching and hql queries on audit data made us chose db
>> store].
>> > > > > A slightly off track question relating to dbstore is, for sql queries if two different packages have the same
>> name for an eclass how would one formulate a sql query using this eclass.
>> > > > > Thanks,
>> > > Ashish
>
>
Cheers
/Eike
----
http://www.esc-net.de
http://thegordian.blogspot.com
http://twitter.com/eikestepper
|
|
|
Re: [CDO] DBStore support for join and async query [message #1227352 is a reply to message #1226973] |
Sat, 04 January 2014 08:21 |
Ashish Shinde Messages: 21 Registered: August 2013 |
Junior Member |
|
|
Hi Eike,
Thanks for the reply. Is there an easy / relatively easy way to convert these column back into CDOObjects.
Also a bit off track but will these results correspond to the view/transaction timestamp if one is set. This might be important for our use case.
I glanced a bit at the sql query handler code and it seemed to me that I might get results for all timestamps. Could not locate additional timestamp contraint being applied here.
I will give this a spin though, however do you know offhand how timestamps might work with a mapquery.
Thanks and regards,
- Ashish
Eike Stepper wrote on Fri, 03 January 2014 02:41Am 02.01.2014 12:16, schrieb Erdal Karaca:
> The SQL handler only checks the first column if the query is an "object query" (which is the default if you have not
> set that paramter).
> I guess you have to file an enhancement request.
You can explicitely tell the SQLQueryHandler to return all column values (instead of using the first column to identify
a CDOObject):
CDOQuery query = transaction.createQuery("sql", "SELECT street, city, name FROM model1_customer ORDER BY street");
*query.setParameter("cdoObjectQuery", false);*
List<Object[]> results = query.getResult(Object[].class);
Or return each row as a map:
CDOQuery query = transaction.createQuery("sql", "SELECT street, city, name FROM model1_customer ORDER BY street");
query.setParameter("cdoObjectQuery", false);
*query.setParameter("mapQuery", true);*
List<Map<String, Object>> results = query.getResult();
Cheers
/Eike
----
http://www.esc-net.de
http://thegordian.blogspot.com
http://twitter.com/eikestepper
>
> Ashish Shinde wrote on Thu, 02 January 2014 10:44
>> Hi Erdal,
>>
>> Yes the DBStore executes the join SQL query by delegating it to the backend, however the problem I am facing is that
>> the SQLQueryHandler returns, only the first object for each query result instead of all components of the join.
>>
>> e.g. for the query select table1.*, table2.* from table1,table2 , the result one would get from the db would be the
>> table1_object1 (as columns), table2_object1 (as columns)
>> table1_object2 (as columns), table2_object2 (as columns)
>> table1_object3 (as columns), table2_object3 (as columns)
>>
>> however the dbstore query returns table1_object1,
>> table1_object2, table1_object3
>>
>> ignoring all objects from table2.
>> Hence the question is does/will dbstore support join queries where the exact join result is returned to the caller
>> instead of only objects from first table in the join.
>>
>> Thanks and regards,
>> - Ashish
>>
>> Erdal Karaca wrote on Wed, 01 January 2014 05:55
>> > The DBStore executes the SQL statement by delegating to the underlying backend.
>> > This is comparable to Hibernate's/JPA's native queries.
>> > > CDO generates the tables such that they are unique, for example, for an EClass mypackage.A, the table name may be
>> mypackage_ns_uri_A (where mypackage_ns_uri = the EPackage's namespace URI prefix).
>> > The best (at the moment) is to have a look at the database table names that are generated.
>> > > Ashish Shinde wrote on Wed, 01 January 2014 07:44
>> > > Hi,
>> > > > > We are using CDO with DBStore for our project. > > > > The sql handler for DBStore looked to not handle join
>> queries. As in the first object from the join result was returned back. > > > > Does dbstore support joins? If so how
>> do I formulate queries to return join results. If not is there some work in progress in this regard. [ Hibernate
>> store looked to support joins but the lack of support for branching and hql queries on audit data made us chose db
>> store].
>> > > > > A slightly off track question relating to dbstore is, for sql queries if two different packages have the same
>> name for an eclass how would one formulate a sql query using this eclass.
>> > > > > Thanks,
>> > > Ashish
>
>
|
|
|
Re: [CDO] DBStore support for join and async query [message #1227357 is a reply to message #1227352] |
Sat, 04 January 2014 08:31 |
|
Am 04.01.2014 09:21, schrieb Ashish Shinde:
> Hi Eike,
>
> Thanks for the reply. Is there an easy / relatively easy way to convert these column back into CDOObjects.
If the ID of the object is part of the result row you can pass it into view.getObject() to load the CDOObject.
> Also a bit off track but will these results correspond to the view/transaction timestamp if one is set. This might be
> important for our use case.
No. In order to respect the view target, i.e., branch and timestamp, you need to specify your SQL query accordingly.
>
> I glanced a bit at the sql query handler code and it seemed to me that I might get results for all timestamps. Could
> not locate additional timestamp contraint being applied here.
See above.
> I will give this a spin though, however do you know offhand how timestamps might work with a mapquery.
I don't think that these aspects are related. The mapQuery=true parameter influences the representation of the returned
query results. The timestamps would only be used/considered in the WHERE clause of the query.
Cheers
/Eike
----
http://www.esc-net.de
http://thegordian.blogspot.com
http://twitter.com/eikestepper
> Thanks and regards,
> - Ashish
>
> Eike Stepper wrote on Fri, 03 January 2014 02:41
>> Am 02.01.2014 12:16, schrieb Erdal Karaca:
>> > The SQL handler only checks the first column if the query is an "object query" (which is the default if you have
>> not > set that paramter).
>> > I guess you have to file an enhancement request.
>> You can explicitely tell the SQLQueryHandler to return all column values (instead of using the first column to
>> identify a CDOObject):
>>
>> CDOQuery query = transaction.createQuery("sql", "SELECT street, city, name FROM model1_customer ORDER BY
>> street");
>> *query.setParameter("cdoObjectQuery", false);*
>>
>> List<Object[]> results = query.getResult(Object[].class);
>>
>> Or return each row as a map:
>>
>> CDOQuery query = transaction.createQuery("sql", "SELECT street, city, name FROM model1_customer ORDER BY street");
>> query.setParameter("cdoObjectQuery", false);
>> *query.setParameter("mapQuery", true);*
>>
>> List<Map<String, Object>> results = query.getResult();
>>
>> Cheers
>> /Eike
>>
>> ----
>> http://www.esc-net.de
>> http://thegordian.blogspot.com
>> http://twitter.com/eikestepper
>>
>>
>> >
>> > Ashish Shinde wrote on Thu, 02 January 2014 10:44
>> >> Hi Erdal,
>> >>
>> >> Yes the DBStore executes the join SQL query by delegating it to the backend, however the problem I am facing is
>> that >> the SQLQueryHandler returns, only the first object for each query result instead of all components of the join.
>> >>
>> >> e.g. for the query select table1.*, table2.* from table1,table2 , the result one would get from the db would be the
>> >> table1_object1 (as columns), table2_object1 (as columns)
>> >> table1_object2 (as columns), table2_object2 (as columns)
>> >> table1_object3 (as columns), table2_object3 (as columns)
>> >>
>> >> however the dbstore query returns table1_object1,
>> >> table1_object2, table1_object3
>> >>
>> >> ignoring all objects from table2.
>> >> Hence the question is does/will dbstore support join queries where the exact join result is returned to the caller
>> >> instead of only objects from first table in the join.
>> >>
>> >> Thanks and regards,
>> >> - Ashish
>> >>
>> >> Erdal Karaca wrote on Wed, 01 January 2014 05:55
>> >> > The DBStore executes the SQL statement by delegating to the underlying backend.
>> >> > This is comparable to Hibernate's/JPA's native queries.
>> >> > > CDO generates the tables such that they are unique, for example, for an EClass mypackage.A, the table name may
>> be >> mypackage_ns_uri_A (where mypackage_ns_uri = the EPackage's namespace URI prefix).
>> >> > The best (at the moment) is to have a look at the database table names that are generated.
>> >> > > Ashish Shinde wrote on Wed, 01 January 2014 07:44
>> >> > > Hi,
>> >> > > > > We are using CDO with DBStore for our project. > > > > The sql handler for DBStore looked to not handle
>> join >> queries. As in the first object from the join result was returned back. > > > > Does dbstore support joins?
>> If so how >> do I formulate queries to return join results. If not is there some work in progress in this regard. [
>> Hibernate >> store looked to support joins but the lack of support for branching and hql queries on audit data made
>> us chose db >> store].
>> >> > > > > A slightly off track question relating to dbstore is, for sql queries if two different packages have the
>> same >> name for an eclass how would one formulate a sql query using this eclass.
>> >> > > > > Thanks,
>> >> > > Ashish
>> >
>> >
>
>
Cheers
/Eike
----
http://www.esc-net.de
http://thegordian.blogspot.com
http://twitter.com/eikestepper
|
|
|
Re: [CDO] DBStore support for join and async query [message #1227450 is a reply to message #1227357] |
Sat, 04 January 2014 14:59 |
Ashish Shinde Messages: 21 Registered: August 2013 |
Junior Member |
|
|
Thank you for the reply.
Would view.getObject() result in an extra database query ? If so is this avoidable since the query might have fetched all the attributes for the corresponding CDOObject.
Thanks and regards,
- Ashish
Eike Stepper wrote on Sat, 04 January 2014 03:31Am 04.01.2014 09:21, schrieb Ashish Shinde:
> Hi Eike,
>
> Thanks for the reply. Is there an easy / relatively easy way to convert these column back into CDOObjects.
If the ID of the object is part of the result row you can pass it into view.getObject() to load the CDOObject.
> Also a bit off track but will these results correspond to the view/transaction timestamp if one is set. This might be
> important for our use case.
No. In order to respect the view target, i.e., branch and timestamp, you need to specify your SQL query accordingly.
>
> I glanced a bit at the sql query handler code and it seemed to me that I might get results for all timestamps. Could
> not locate additional timestamp contraint being applied here.
See above.
> I will give this a spin though, however do you know offhand how timestamps might work with a mapquery.
I don't think that these aspects are related. The mapQuery=true parameter influences the representation of the returned
query results. The timestamps would only be used/considered in the WHERE clause of the query.
Cheers
/Eike
----
http://www.esc-net.de
http://thegordian.blogspot.com
http://twitter.com/eikestepper
> Thanks and regards,
> - Ashish
>
> Eike Stepper wrote on Fri, 03 January 2014 02:41
>> Am 02.01.2014 12:16, schrieb Erdal Karaca:
>> > The SQL handler only checks the first column if the query is an "object query" (which is the default if you have
>> not > set that paramter).
>> > I guess you have to file an enhancement request.
>> You can explicitely tell the SQLQueryHandler to return all column values (instead of using the first column to
>> identify a CDOObject):
>>
>> CDOQuery query = transaction.createQuery("sql", "SELECT street, city, name FROM model1_customer ORDER BY
>> street");
>> *query.setParameter("cdoObjectQuery", false);*
>>
>> List<Object[]> results = query.getResult(Object[].class);
>>
>> Or return each row as a map:
>>
>> CDOQuery query = transaction.createQuery("sql", "SELECT street, city, name FROM model1_customer ORDER BY street");
>> query.setParameter("cdoObjectQuery", false);
>> *query.setParameter("mapQuery", true);*
>>
>> List<Map<String, Object>> results = query.getResult();
>>
>> Cheers
>> /Eike
>>
>> ----
>> http://www.esc-net.de
>> http://thegordian.blogspot.com
>> http://twitter.com/eikestepper
>>
>>
>> >
>> > Ashish Shinde wrote on Thu, 02 January 2014 10:44
>> >> Hi Erdal,
>> >>
>> >> Yes the DBStore executes the join SQL query by delegating it to the backend, however the problem I am facing is
>> that >> the SQLQueryHandler returns, only the first object for each query result instead of all components of the join.
>> >>
>> >> e.g. for the query select table1.*, table2.* from table1,table2 , the result one would get from the db would be the
>> >> table1_object1 (as columns), table2_object1 (as columns)
>> >> table1_object2 (as columns), table2_object2 (as columns)
>> >> table1_object3 (as columns), table2_object3 (as columns)
>> >>
>> >> however the dbstore query returns table1_object1,
>> >> table1_object2, table1_object3
>> >>
>> >> ignoring all objects from table2.
>> >> Hence the question is does/will dbstore support join queries where the exact join result is returned to the caller
>> >> instead of only objects from first table in the join.
>> >>
>> >> Thanks and regards,
>> >> - Ashish
>> >>
>> >> Erdal Karaca wrote on Wed, 01 January 2014 05:55
>> >> > The DBStore executes the SQL statement by delegating to the underlying backend.
>> >> > This is comparable to Hibernate's/JPA's native queries.
>> >> > > CDO generates the tables such that they are unique, for example, for an EClass mypackage.A, the table name may
>> be >> mypackage_ns_uri_A (where mypackage_ns_uri = the EPackage's namespace URI prefix).
>> >> > The best (at the moment) is to have a look at the database table names that are generated.
>> >> > > Ashish Shinde wrote on Wed, 01 January 2014 07:44
>> >> > > Hi,
>> >> > > > > We are using CDO with DBStore for our project. > > > > The sql handler for DBStore looked to not handle
>> join >> queries. As in the first object from the join result was returned back. > > > > Does dbstore support joins?
>> If so how >> do I formulate queries to return join results. If not is there some work in progress in this regard. [
>> Hibernate >> store looked to support joins but the lack of support for branching and hql queries on audit data made
>> us chose db >> store].
>> >> > > > > A slightly off track question relating to dbstore is, for sql queries if two different packages have the
>> same >> name for an eclass how would one formulate a sql query using this eclass.
>> >> > > > > Thanks,
>> >> > > Ashish
>> >
>> >
>
>
|
|
| | |
Goto Forum:
Current Time: Fri Sep 13 19:25:55 GMT 2024
Powered by FUDForum. Page generated in 0.04400 seconds
|