Search the web
Sign In
New User? Sign Up
SimpleORM
? Already a member? Sign in to Yahoo!

Yahoo! Groups Tips

Did you know...
Want to share photos of your group with the world? Add a group photo to Flickr.

Best of Y! Groups

   Check them out and nominate your group.
Having problems with message search? Fill out this form to ensure your group is one of the first to be migrated to the new message search system.

Messages

  Messages Help
Advanced
The Big Split -- SimpleOrm.records and SimpleOrm.database.   Message List  
Reply | Forward Message #1551 of 1851 |
Re: [SimpleORM] The Big Split -- SimpleOrm.records and SimpleOrm.database.

Anthony,

maybe we should consider introducing SDataSet (or SDataSetManager ?)
right now.
First it would be equivalent to SConnection's transaction cache and
could NOT be detached "per se".
But maybe later, it could be.

This could allow to have the following API :

SQuery<Employee> qry = new SQuery(Employee.meta).eq(EMPEE_ID, "123");

SConnection.attach(datasource);
SConnection.begin();
SDataSet ds = SConnection.getDataSet();
Set<Employee> rs = ds.execute(qry);

or a shortcut

Set<Employee> rs = SConnection.execute(qry);
and SConnection would delegate to its internal SDataSet implementation.

This would be consistant with the idea of applying simple queries to
SDataSet outside of a database (detached). So in the future, we could do
this, without breaking the API :

SDataSet ds = SConnection.detachDataSet();
...in another tier...
Set<Employee> rs = ds.execute(qry);

Also SFinder could be a subclass of SQuery. And we could do :

SFinder<Employee> finder = new SFinder(Employee.meta);
finder.setPirmaryKey("123");
Employee emp = ds.mustFind(finder); // throws exception if not found
or
Employee emp = ds.find(finder); // return null if not found
or
Set<Employee> emp = ds.execute(finder); // generic execute, return an
empty set or a single value set

and also :

ds.findOrCreate(finder);

I don't know if we need a SResultSet. Maybe it could remain internal to
Simpleorm, or at least to the .database part.

Does it make sense ?

Regarding my time, as everybody, I have a ton of important things to
do :), but I will definitely find some time to get Sorm 3 right !

Regards,
Franck

Le lundi 30 juin 2008 à 20:44 +1000, Anthony & Melissa Berglas a écrit :
> Hello Frank,
>
> Moving SQuery out is possible. One would have to
> store the built query as a structure rather than
> a query string, and then translate to string in .database. eg.
> eq(this, that) {
> operationsList.add(new Eq(this, that));
> }
> A little bit of extra overhead, but doable. Much
> better to have query SQL built in SDriver.
>
> What would the API look like? Maybe
>
> SQuery<Employee> qry = new SQuery(Employee.meta).eq(EMPEE_ID, "123");
> SResultSet<Employee> rs = new SResultSet(qry).execute();
> and maybe
> Employee[] emps = new SFinder(qry).execute();
>
> (Cannot have qry.execute() because that crosses the boundary.)
>
> Having SQuery in the record part would also mean
> that one could later apply simple queries to a
> DataSet (ie.list) of records, outside a database which would be cool.
>
> We could also choose to keep the existing API if
> we have a database accessor interface written in
> .record but implemented in .database. But we
> then need to keep a pointer to the
> implementation, either in a static or another
> thread local. This produces a slightly neater
> API but is much less transparent.
>
> What do you think? Please propose an API style that would suit you.
>
> Going forward, do you have time this week? I
> would like to start by cutting out the finder
> code in SRecordMeta, which is an internal change.
>
> Sorry about the non-public method. If we split
> this then all the meta data will need to be
> public so that the .database part can access it!
>
> Regards,
>
> Anthony
>
> At 07:24 PM 30/06/2008, Franck Routier wrote:
> >Hello Anthony,
> >
> >I totally second this separation. This makes things much cleaner, and
> >opens the possibility for future evolutions.
> >
> >However, I am not sure I want SQuery to be in the database part...
> >Right now, I build a lot of queries in my business layer, depending
> on
> >business rules, and then execute them in Dao's.
> >Would it be possible to keep SQuery quite conceptual, and let
> >SConnection/SDriver implement the DB specific part. This would also
> make
> >possible to have some different SConnection implementation, say
> towards
> >a ldap repository, etc. (well, I know SQuery join and so on are
> pretty
> >RDBMS oriented...)
> >
> >This would make SQuery kind of a custom query language, which you
> would
> >rather avoid, as said in the whitepaper. But we could keep it as it
> is
> >now, that is a 'tiny' layer over jdbc AND potentialy other stuffs :)
> >Would you consider this option ?
> >
> >By the way, introducing references to SConnection.getDriver() in
> SQuery
> >(for quoting) broke my app. As said before, I tend to build my
> queries
> >outside connections. So I temporay commented it out. The option I
> would
> >go for is to translate SQuery into sql latter on, in
> SPreparedStatement
> >for example. What is your opinion on this ?
> >
> >Also be careful to preserve API visibility, at least for read-only
> >getters. Restricting it to package visibility also breaks a lot of my
> >code for dynamically building queries.
> >
> >
> >That said, I really like your idea.
> >
> >Franck
> >
> >
> >Le lundi 30 juin 2008 à 15:56 +1000, Anthony Berglas a écrit :
> > > Hello Franck,
> > >
> > > I think that as part of 3.0 we should consider splitting SimpleOrm
> > > into two pieces, each in their own Jars.
> > >
> > > simpleorm.records that contains SRecordMeta, SRecordInstance,
> SField*
> > >
> > > simpleorm.database that contains SQuery, SDriver*, SConnection.
> > >
> > > The record part should have zero dependency on the database part,
> and
> > > should be compiled and built into its own jar, with some test
> cases of
> > > its own.
> > >
> > > The database part should depend on the records part, obviously.
> > >
> > > When working detached, one should only need the .records jar.
> > >
> > > This is actually not that hard to do. I have already decoupled
> > > SQuery from SRecordMeta. A similar trick can be used to decouple
> > > findOrCreate and friends. And the only other substantial
> connection
> > > is where SReferenceField.getRawValue can do a lazy read.
> > >
> > > For findOrCreate, the API becomes slightly messier:-
> > >
> > > SFinder empf<Employee> = new SFinder(Employee.meta);
> > > Employee e = empf.findOrCreate("123");
> > >
> > > or simply but slightly less efficiently
> > >
> > > Employee e = new SFinder(Employee.meta).findOrCreate("123");
> > >
> > > (The finder would cache the sets of different types of fields
> etc.)
> > >
> > > vs old
> > >
> > > Employee e = Employee.meta.findOrCreate("123");
> > >
> > > For the SFieldReference.get the call would become
> > >
> > > SFinder deptf<Department> = new SFinder(Department.meta);
> > > Department dept = deptf.getReference(myEmp, DEPT);(
> > >
> > > (For the detached case, no query:-)
> > > Department dept = myEmp.getUnqueriedReference(DEPT);
> > >
> > > One could, of course, give SRecordMeta a default finder, defined
> > > through an interface in .SRecord, and then keep the existing
> > > API. But being explicit makes the structure clear.
> > >
> > > I have also attached some other prototyping that I was doing in
> > > SimpleData (it is checked in). But I now think that splitting
> > > SimpleOrm is a much better idea, and SimpeData should be
> > > abandoned. I think that this change is actually very good, and
> would
> > > lead naturally to DataSets if we wanted to go there later.
> > >
> > > My current task is to work on the white paper etc. I would not
> want
> > > to start any split until you have caught up with the current
> changes
> > > and your application works 100%. (Although I might be tempted to
> do
> > > some of the internal rearrangement, moving code from SRecordMeta
> to
> > > SFinder.)
> > >
> > > One way or the other I am hoping to make your branch the trunk
> this
> > > week.
> > >
> > > What do you think?
> > >
> > > Anthony
> > >
> > > Dr Anthony Berglas, anthony@... Mobile: +61 4 4838 8874
> > > Just because it is possible to push twigs along the ground with
> ones
> > > nose
> > > does not necessarily mean that is the best way to collect
> firewood.
> > >
> > >
> > >
> > >
>
> Spreadsheet Detective,
> Southern Cross Software Queensland Pty Limited
> 54 Gerler Street
> Bardon, Queensland 4065, Australia.
>
> Email: berglas@...
> www.SpreadsheetDetective.com
> Ph: +61 427 830248 (Australian Eastern Standard Time)
>
> "If the model seems correct only because the numbers look right,
> then why build the model in the first place?"
>
>
>
>
>





Mon Jun 30, 2008 2:24 pm

routier_franck
Offline Offline
Send Email Send Email

Forward
Message #1551 of 1851 |
Expand Messages Author Sort by Date

Hello Franck, I think that as part of 3.0 we should consider splitting SimpleOrm into two pieces, each in their own Jars. simpleorm.records that contains...
Anthony Berglas
aberglas
Offline Send Email
Jun 30, 2008
5:57 am

Hello Frank, Moving SQuery out is possible. One would have to store the built query as a structure rather than a query string, and then translate to string in...
Anthony & Melissa Ber...
berglas@...
Send Email
Jun 30, 2008
10:45 am

Anthony, maybe we should consider introducing SDataSet (or SDataSetManager ?) right now. First it would be equivalent to SConnection's transaction cache and ...
Franck Routier
routier_franck
Offline Send Email
Jun 30, 2008
2:24 pm

Hello Franck, Hmm. The design gets ever more ambitious. I am concerned that if we take on too much we will not finish. But it would be good to get this...
Anthony Berglas
aberglas
Offline Send Email
Jul 1, 2008
11:18 am

Hi Anthony, that seems fine to me, except for one point that is not that clear :) shouldn't "myDS.create(new Employee().set(Employee.ID, "123").set.....);"...
Franck Routier
routier_franck
Offline Send Email
Jul 1, 2008
2:46 pm

Anthony, I've done some work, namely steps 1 to 6, execpt for the 'flush before query part'. Lot of thinks are now public, including some fields. Bad. Also...
Franck Routier
routier_franck
Offline Send Email
Jul 1, 2008
7:59 pm

Hello Franck, Wow, you have been busy. I agree that we need to be careful about our vocabulary, I had been a bit sloppy. SCon."attach/detach" had referred to ...
Anthony Berglas
aberglas
Offline Send Email
Jul 2, 2008
10:18 am

Hello Anthony, I agree with everything you say here. Regarding naming, maybe we should consider JPA terminology ? Then Session would be EntityManager. And...
Franck Routier
routier_franck
Offline Send Email
Jul 2, 2008
10:52 am

Hello Franck, You've been busy again. ... I'm not sure that joinTranction a good description for SSession.open. Maybe ...
Anthony Berglas
aberglas
Offline Send Email
Jul 3, 2008
5:11 am

Hi, ok, I really like SSession.newSessionAndAssociateWithCurrentThreadAndOpenJdbcConnection(), which really says what it does..... :) I agree with the fact...
Franck Routier
routier_franck
Offline Send Email
Jul 3, 2008
7:50 am

Anthony, I was wondering, why must have so many static methods in SSession, that most of the time end up finding the current scon in threadlocal, instead of...
Franck Routier
routier_franck
Offline Send Email
Jul 3, 2008
12:35 pm

Hmm. The motivations for attaching the session to a thread local were:- 1. It avoids having to pass a connection variable everywhere. In a database...
Anthony Berglas
aberglas
Offline Send Email
Jul 4, 2008
2:11 am

Hello Franck To keep it simple, the semantics of attaching a data set to a session could be exactly the same as attaching each record in it, one by one. As ...
Anthony Berglas
aberglas
Offline Send Email
Jul 4, 2008
12:47 am
Advanced

Copyright © 2009 Yahoo! Inc. All rights reserved.
Privacy Policy - Terms of Service - Guidelines - Help