Interesting discussion.

I'm on the verge of NoSQL databases, I prototyped a system with Voyage
but didn't feel confident enough as to continue with it to a
production system.

One of the things that held me back was the lack of tooling[*] and how
hard would it be to change something from "outside" of Voyage.
I used ORM in several fashions for over a decade, and wrote one in my
last job, so I rely more on SQL than anything else.

[*] Have tried running a "complex" query using MongoDB? It's JSON
syntax is awful. Fortunately MongoTalk does most of the heavylifting,
but as said before, if for any reason I need to run a query from
outside (using any other mongo client) it is not going to be easy. To
me SQL is concise.

I know need a mindset change, which I look forward to get. But today I
still have to deal with the utter-verbose definition of GLORP's
DescriptionSystem


Regards,

Esteban A. Maringolo


2014-04-25 6:30 GMT-03:00 Norbert Hartl <norb...@hartl.name>:
> Joachim,
>
> Am 25.04.2014 um 10:58 schrieb jtuc...@objektfabrik.de:
>
> Hi Norbert,
>
> I am way too old for holy wars ;-)
>
> So in essence, we are both saying that hammering objects into either an SQL
> or NoSQL database can be hard and both approaches have negative drawbacks as
> well as plusses.
>
>
> Yes.
>
> I didn't come up with Transactions because they also can make things hard.
> See the atomic counter question from a few days ago.IN ORMs you usually end
> up with both image-side and database-side implementations of Transactions,
> and this can be helpful and complicated at the same time. Sometimes you'd
> just like to save one object without saving lots of associated ones from the
> same unit of work.
>
> Does this all lead us to the object database grounds? Or is it all just a
> debate of taste and faith? I am still wondering if my life would be easier
> if I used an object database (Gemstone comes to mind, but also Magma). And
> still I cannot find the final answer.
>
>
> The choice for a technology is not a choice about having more or less
> problems but about which problems you like to have and which ones to avoid.
>
> The problem we have is that main memory is persistent. The separation
> between to the kinds of memories is pain. OODBMs are the closest to mitigate
> the gap. Theoretical it is hard to decide that. It depends one what you do.
> I don’t use SQL databases because I like to work with objects. I use
> GemStone for quite some years now which is fantastic in certain cases. But I
> have projects where I need geo spatial and fulltext indexes (and fast
> hierarchical queries). As GemStone does not provide them (the hierarchical
> fast query you get by using gemstone specific stuff) and I don’t want to
> implement them I need something else. MongoDB is good at indexing geo
> spatial stuff. So mongo + voyage is a good fit for this. I need to do
> explicit commits and have to do additional house keeping both of them you
> don’t need to do in GemStone. But I get the indexing capability I need. We
> also do statistical aggregation of data. I used to do it with mongo and
> map-reduce jobs at night but it is cumbersome. Now I use elasticsearch for
> that because I can put in JSON and I get rich and fast query cababilities.
> So my choices of persistence are always driven by the use case (any my
> laziness of course)
>
>
> Maybe that is because I have some knowledge with ORM, but very little with
> OODBMS.
>
> No matter what, my initial point should have been that I think it is naive
> to think that NoSQL DBs solve a lot of the problems you have with RDBMS.
> They just don't address them, and if you don't see som eof these problems in
> your domain, I guess you're best off using NoSQL.
>
> Agreed.
>
> ObjectID and stuff in mongo still means you have to make design decisions
> and implement something to assign/retrieve those ids and store them in
> places where you want to reference your objects. So you do a subset of the
> bookkeeping that an RDBMS can do for you by hand. Is that a fair way to put
> it?
>
> You use Glorp and I use Voyage. It is basically the same in this regard.
>
> You made a good point and I tend to agree to most of what you say.
>
> Thanks!
>
> Norbert
>
> Joachim
>
>
>
>
> Am 25.04.14 10:35, schrieb Norbert Hartl:
>
> Joachim,
>
> thanks for your explanation. I appreciate that. I was thinking if it is a
> good idea to write my mail. Usually this ends in a holy war which I don’t
> want. Comments inline.
>
> Am 25.04.2014 um 09:02 schrieb jtuc...@objektfabrik.de:
>
> Norbert,
>
> you are right, I should have given an example of what I mean.
>
> So here is one:
>
> If you serialize an object graph to, say, json and store it in a NoSQL DB,
> you need to decide how "deep" you serialize your graph into one djson
> document and how to build up segments of your graph that need to be
> serialized separately, like for an equivalent of an 1:n relationship.
> Exanple: an Order contains OrderItems, each of which reference a Product.
> But the Product can be referenced from many OrderItems. So you need to "cut
> off" parts of your model to serialize them separately. And you need a way to
> save the "reference“.
>
>
> You can do that in e.g. mongo as well. You just use on ObjectId as a field
> value or you use a DBRef. Btw. what you describe is not 1:n but m:n. An
> OrderItems can have n products and a Product can be in m OrderItems.
>
>
> One of the next questions then is "what if I delete a Product?". What
> happens to the OrderItems or InvoiceItems and so on?
>
>
> If you just delete it the collections will have a stale reference. I think
> there is no universal answer to that even if it seems the removal in the
> collection is that universal answer. If it is about integrity you need one
> way to make it happen. Reestablishing of integrity can happen on write time
> or on read time.
> What will happen in a SQL context? You can’t delete an object that is
> pointed to by a foreign key. What does it help then? Not taking your
> business model into account you couldn’t do anything more to find out where
> that reference is. That is probably the only point I wanted to make
> questioning your last mail. If we take that scenario you can only solve it
> if you take the problem one level higher (well, if you have cascading
> deletes you may ignore it). So these problems tend to end in the application
> logic. And that is what my experience tells me. Database ensured integrity
> isn’t much of a help in many cases. So you solve the problems in the
> application logic (knowing which things reference what). Being there I see
> no big differences to using a NoSQL database. In NoSQL those features are
> just not there per se. You have to model it regarding your use case.
>
> None of these problems are unsolvable, but these problems need to be
> addressed either in your persistence framework on top of a NoSQl DB or in
> your application code. In Relational DBs, they've built solutions for these
> problems before you and I were born ;-) I am talking of foreign keys,
> referential integrities and normalization. To my knowledge, these have not
> yet found their standardized counterparts in NoSQL DBs. So NoSQL can be a
> good solution for many problems, but they can also be bad for many others.
>
>
> I’m questioning the use of each of those. As I said above I doubt there are
> many use cases where foreign keys are the best way to go. Btw. if you ever
> administrate a database and you have to recover after a crash then you might
> have a different view on foreign keys because they are able to make it close
> to impossible to load the data back.  Referential integrity is either done
> by the database by foreign keys or in the application logic as I said above.
> The need for normalization is heavily use case depend. It is nothing good
> per se. So these are not good examples IMHO. I’m wondering you didn’t bring
> up the only good reason for SQL databases (for most). For me this is having
> atomic operations using transactions. This is the one case that can drive
> you nuts if try to model something with a NoSQL database to achieve it.
>
>
> I am not saying anything new here. This debate has been going on for decades
> already, and much more clever people than me have made good points for both
> sides over the years now.
>
>
> Sure. But from time to time it is good to refresh the memory. And for me you
> are clever enough ;)
>
>
> You also asked for examples for problems you get from using Glorp.
>
> One of my biggest concerns is that it can be hard to model an m:n
> relationship where one or both sides of the relationship are abstract
> superclasses (or even concrete ones with multiple subclasses). It gets even
> harder when you want to be able to associate an object (like a Category or
> Tag) to "anything". This really is hard or involves some additional coding
> on top of the persistence framework.
>
> Glorp does miss one feature painfully: The ability to map classes with
> subclasses that spread over three or more "subtables" for the subclasses.
> This one is hard to explain: if you have a superclass "Vehicle" with two
> subclasses "FlyingVehicle" and "DrivingVehicle", both of which have
> subclasses, there is no support for a model which has tables on the
> "FlyingVehicle" or "DrivingVehicle" level. You must model your DB in a way
> that there are all attributes in a "Vehicle" table or in the "Car", "Train",
> "Spaceship" and "Kite" tables. This really is a pity and I don't think
> anybody is working on changing this any time soon.
>
> Yep. Dealing with these cases I learned that Objects and SQL databases don’t
> fit together and why ORM cannot work. I mean Glorp is really good at that by
> providing your use case with subclasses via virtual lookups. I don’ remember
> how it works. It was like a descriptor with candidate classes which lead to
> multiple lookups. I figured that out while talking to Alan 8 years ago. I
> think I managed it by using a three column m:n mapping table where you have
> the two ids and an identifier that gives a hint which subclass/table it is
> to look into. Anyway even if Glorp supported sublasses lookups it was a can
> of worms to open. I once changed a single thing in my glorp descriptions and
> then the login the web site took 1,5 minutes just because all the magic in
> Glorp produced 432 database lookups initiate by a single button click. You
> just try to force a schema (OO) onto a technology (SQL) that does not
> support this case at all. It is an entity relationship model where the
> entities are flat. Inheritance is not part of the solution.
>
> So the summary would be: A lot of people making big efforts to forcing an
> object model into a technology that doesn’t support it just because they
> want to have features like integrity you can establish in other ways. This
> is why I don’t use SQL databases anymore until I have a use case that does
> benefit from it.
>
>
> Does this explain what I mean?
>
> Yes and I hope I made point also very clear :)
>
> Norbert
>
> Joachim
>
>
>
>
>
>
>
> Am 25.04.14 08:41, schrieb Norbert Hartl:
>
>
>
> Am 25.04.2014 um 06:51 schrieb Joachim Tuchel <jtuc...@objektfabrik.de>:
>
> Hi,
>
> We're using Glorp on VA ST for kontolino.de. It is an active project in the
> sense of somebody is taking care of bugs. The lead developer(s) work(s) for
> Cincom - and Cincom uses Glorp as supported component of CST. Instantiations
> also provides Glorp with VA ST and supports it. Glorp is very stable and is
> not moving fast, which is not a disadvantage for a production system.
> Features are being added and bugs are fixed.
>
> Re: Pharoers do NoSQL: judging from the discussions on this list and others,
> you have to be careful what you need. To me it seems many developers want
> features from relational DBs and hammer them into their applications with
> brute force. The first wow! soon gives room to a lot of problems that have
> been solved in relational DBs three decades ago.
>
> I think such a statement should be based on an example.
>
> But it is true that o/r mapping is not always fun. It can force you to make
> decisions about your model that look strange from the object perspective.
>
> Agreed. And especially in the context of O/R I'm curious what will be your
> example to prove your point above.
>
> Couldn't resist,
>
> Norbert
>
> I'd either go full objects (gemstone, magma) or relational for my typical
> projects (business apps).
>
> Hth
>
> Joachim
>
> Clément Bera <bera.clem...@gmail.com> schrieb:
>
> Hello,
>
> I think Glorp is used with DBXTalk for relational databases by multiple
> people.
>
> Usually, with Pharo, people use as a persistance layer either MongoDB with
> the frameworks MongoTalk/Voyage.
>
> Gemstone is also used quite often for large scale application but Gemstone
> is not free.
>
> Regards.
>
>
> 2014-04-23 20:34 GMT-07:00 Pablo R. Digonzelli <pdigonze...@gmail.com>:
>>
>> Hi all, can someone tell me if glorp is active there ar is using glorp or
>> other persistence framework in production projects?
>>
>> Tia
>>
>> ________________________________
>> Ing. Pablo Digonzelli
>> Software Solutions
>> IP-Solutiones SRL
>> Metrotec SRL
>> 25 de Mayo 521
>> Email: pdigonze...@softsargentina.com
>> pdigonze...@gmail.com
>> Cel: 5493815982714
>>
>
>
>
> --
> -----------------------------------------------------------------------
> Objektfabrik Joachim Tuchel          mailto:jtuc...@objektfabrik.de
> Fliederweg 1                         http://www.objektfabrik.de
> D-71640 Ludwigsburg                  http://joachimtuchel.wordpress.com
> Telefon: +49 7141 56 10 86 0         Fax: +49 7141 56 10 86 1
>
>
>
>
> --
> -----------------------------------------------------------------------
> Objektfabrik Joachim Tuchel          mailto:jtuc...@objektfabrik.de
> Fliederweg 1                         http://www.objektfabrik.de
> D-71640 Ludwigsburg                  http://joachimtuchel.wordpress.com
> Telefon: +49 7141 56 10 86 0         Fax: +49 7141 56 10 86 1
>
>

Reply via email to