Beefy Boxes and Bandwidth Generously Provided by pair Networks
Welcome to the Monastery
 
PerlMonks  

Re^2: DB persistence framework for Perl Classes

by gmpassos (Priest)
on Oct 17, 2004 at 00:49 UTC ( [id://399850]=note: print w/replies, xml ) Need Help??


in reply to Re: DB persistence framework for Perl Classes
in thread DB persistence framework for Perl Classes

Humm, in lines of code and DB portability?

Graciliano M. P.
"Creativity is the expression of the liberty".

Replies are listed 'Best First'.
•Re^3: DB persistence framework for Perl Classes
by merlyn (Sage) on Oct 17, 2004 at 05:21 UTC
    Lines of code don't matter as long as I'm not writing them.

    Portability? You can go all the way from SQLite through PostgreSQL through Oracle (we've done it) with Class::DBI. How much more portable do you want to be? Flat files? {grin}

    I won't be interested in your project unless you can give me better reasons than that. In fact, I'd actively discourage you from inventing your own shiny wheel, while not contributing to Class::DBI if you feel something is missing there.

    -- Randal L. Schwartz, Perl hacker
    Be sure to read my standard disclaimer if this is a reply.

      From what I understand, Class::DBI needs a existing data-model to derive its classes from while HDB does not impose that constraint. At least, that was one of the constraints of Class::DBI when I looked at it, which has been a while ago.

      -- JaWi

      "A chicken is an egg's way of producing more eggs."

      Some Larry words:
    • ...To not try to discourage people from trying variances. We do not want to stabelish one church, we want to stabelish many denominations...
    • Sincerely I have never used Class::DBI in a deep way, and I will be glad if you can show me how to do what I'm trying to do here with Class::DBI, and if I think that something is missing I will add to Class::DBI as I have added to other modules.

      About lines of code, well, for me lines matters, specially for Perl, since we don't have a nice IDE with wizards like in Java were we really don't need to write things. Perl means write your own code.

      And about the portability of Class::DBI, I can be wrong, but you are saying to me that DBI is portable over databases. Well, the SQL is not.

      About my time, I'm paid to create components that help our development.

      Graciliano M. P.
      "Creativity is the expression of the liberty".

        And about the portability of Class::DBI, I can be wrong, but you are saying to me that DBI is portable over databases. Well, the SQL is not.

        As somebody who fell into the "gotta write my own abstraction layer" trap, I have to disagree here.

        Class::DBI exists to allow you to not write SQL; problems with database portability I've run into have been limitations in the DBD layer of DBI and not related to Class::DBI directly. A good example of this is trying to access MS SQL Server; DBD::Sybase doesn't support bind parameters using the FreeTDS library.

        Code like this:

        my $item = db::Inventory::Item->retrieve( 15 ); if( $item ) { $item->quantity( 15 ); }
        works with every database I've tried so far where a Class::DBI driver exists.

        If you're worried about database portability, you have to take into account variants of "sequence" methodologies across various databases. For example, both Postgres and Oracle have an object called a sequence, but they access them differently:

        -- Oracle: INSERT INTO my_table VALUES( my_sequence.nextval, 'Some Value' ); -- Postgres: INSERT INTO my_table VALUES( nextval( 'my_sequence' ), 'Some Value' );
        Heaven forbid you want to use a database where sequences don't exist but you want autoincrementing fields, say MySQL or SQL Server/Sybase:
        --MySQL INSERT INTO my_table( seq_field, val_field ) VALUES (NULL, 'Some Value'); SELECT LAST_INSERT_ID(); -- SQL Server INSERT INTO my_table( val_field ) VALUES ( 'Some Value' ); SELECT SCOPE_IDENTITY();
        Not to mention that MySQL will insert a requested value into the sequence field (if it doesn't violate a primary key constraint), where SQL Server will barf if you attempt to place any value into an autoincrementing field.

        The code to do this with Class::DBI is exactly the same, no matter what database layer you deal with:

        my $newRecord = db::Table->create( { val_field => 'Some Value' } );
        And you don't have to deal with rewriting your SQL to handle different funkiness associated with different back ends. It Just Works.

        Granted, there are things I don't like about Class::DBI:

        • No really nice way to handle views
        • Docs for dealing with different connection settings are, shall we say, sparse. I still can't figure out how to have one set of user/password fields for, say, a web application and another for the command-line processing without duplicating the whole hierarchy
        • Relationships can be a bit funky to deal with.
        • Transaction support is really funky for long-running processes like mod_perl where you might want some records acted upon immediately and others batched

        What I tend to do is use Class::DBI for my user-type interactions where editing and small selection is involved (update my user preferences, edit an item, etc.) and use raw SQL for reporting in the web environment.

        For back-end batch processing, I tend to do everything with raw DBI/Perl code unless I have to iterate over every single record and the queries driving my main batch loop aren't JOINed tables.

        I have no problem with you reinventing the wheel if you've already studied other wheels. It's now clear that you haven't. Please study Class::DBI. Do not reinvent it without first figuring out exactly why it won't work for you.

        And it's not your time I care about (very much). It's the time it'll take the next guy to sort out your tiny implementation from the others that are on the CPAN. You waste everyone's time when you upload stuff that could have been done so much easier, had you just taken the time to know what already exists.

        The SQL used by Class::DBI is in fact portable to that list I've already given. Please to not be confusing issues here.

        -- Randal L. Schwartz, Perl hacker
        Be sure to read my standard disclaimer if this is a reply.

        About lines of code, well, for me lines matters, specially for Perl, since we don't have a nice IDE with wizards like in Java were we really don't need to write things. Perl means write your own code.

        You and merlyn are talking past each other. merlyn, AFAICT, is talking about the number of lines in the distributions being used. You, AFAICT, are talking about the number of lines you need to use in order to stitch together the distributions. Two completely different things.

        As for IDEs ... it sounds like you really haven't used Java if you feel you can say such things. Granted, I haven't either, but people whose skills I trust have and, frankly, I don't think it's as you make out. Plus, if you use ActiveState, you have Komodo which is a full-fledged Perl IDE with almost as many features as Visual Studio.

        Perl means write your own code.

        You are taking a position here without thinking it through.. Frankly, Perl, to me, means don't write your own code! One of the primary reasons I use Perl is the existence of CPAN. Millions of lines of code, that I did not write, that I can plug straight into any project I am working on. In fact, not only did I not write it, but I don't maintain it. Even better!

        About my time, I'm paid to create components that help our development.

        That's funny. That's exactly what I'm paid to do, too. And, frankly, I work solely on the components that, after researching the topic as thoroughly as I can, I cannot find a CPAN module to do it. If the component has a serious impact upon our development, I estimate a good amount of hours to do it. If I can find some CPAN module that does it for me, I can goof off the rest of the time. Perl hackers are "Lazy", remember? :-)

        Being right, does not endow the right to be rude; politeness costs nothing.
        Being unknowing, is not the same as being stupid.
        Expressing a contrary opinion, whether to the individual or the group, is more often a sign of deeper thought than of cantankerous belligerence.
        Do not mistake your goals as the only goals; your opinion as the only opinion; your confidence as correctness. Saying you know better is not the same as explaining you know better.

Log In?
Username:
Password:

What's my password?
Create A New User
Domain Nodelet?
Node Status?
node history
Node Type: note [id://399850]
help
Chatterbox?
and the web crawler heard nothing...

How do I use this?Last hourOther CB clients
Other Users?
Others having a coffee break in the Monastery: (3)
As of 2024-03-29 04:37 GMT
Sections?
Information?
Find Nodes?
Leftovers?
    Voting Booth?

    No recent polls found