The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.

Name

QBit::Application::Model::DB - base class for DB.

Description

Base class for working with databases.

GitHub

https://github.com/QBitFramework/QBit-Application-Model-DB

Install

Debug

$QBit::Application::Model::DB::DEBUG = TRUE;

Abstract methods

Package methods

meta

Arguments:

Example:

package Test::DB;

use qbit;

use base qw(QBit::Application::Model::DB);

my $meta = {
    tables => {
        users => {
            fields => [
                {name => 'id',        type => 'INT',      unsigned => 1, not_null => 1, autoincrement => 1,},
                {name => 'create_dt', type => 'DATETIME', not_null => 1,},
                {name => 'login',     type => 'VARCHAR',  length => 255, not_null => 1,},
            ],
            primary_key => [qw(id)],
            indexes     => [{fields => [qw(login)], unique => 1},],
        },

        fio => {
            fields => [
                {name => 'user_id'},
                {name => 'name',    type => 'VARCHAR', length => 255,},
                {name => 'midname', type => 'VARCHAR', length => 255,},
                {name => 'surname', type => 'VARCHAR', length => 255,},
            ],
            foreign_keys => [[[qw(user_id)] => 'users' => [qw(id)]]]
        },
    },
};

__PACKAGE__->meta($meta);

in Appplication.pm

use Test::DB accessor => 'db';

get_all_meta

Arguments:

Return values:

Example:

my $meta = $app->db->get_all_meta('Test::DB');

init

No arguments.

Method called from "new" before return object.

quote

Arguments:

Return values:

Example:

my $quoted_name = $app->db->quote('users'); # 'users'

quote_identifier

Arguments:

Return values:

Example:

my $quoted_name = $app->db->quote_identifier('users'); # "users"

begin

No arguments.

start a new transaction or create new savepoint

Example:

$app->db->begin();

commit

No arguments.

commits the current transaction or release savepoint

Example:

$app->db->commit();

rollback

No arguments.

rolls back the current transaction or savepoint

Example:

$app->db->rollback();

transaction

Arguments:

Example:

$app->db->transaction(sub {
    # work with db
    ...
});

create_sql

Arguments:

Return values:

Example:

my $sql = $app->db->create_sql(qw(users));

init_db

Arguments:

Example:

$app->db->init_db(qw(users));

finish

No arguments.

Check that transaction closed

Example:

$app->db->finish();

Internal packages

Name

QBit::Application::Model::DB::Class

Description

Base class for DB modules.

RO accessors

Package methods

init

quote

quote_identifier

filter

For more information see code and test.

Name

QBit::Application::Model::DB::Field

Description

Base class for DB fields.

RO accessors

Package methods

init

init_check

Abstract methods

For more information see code and test.

Name

QBit::Application::Model::DB::Filter

Description

Base class for DB filters.

Package methods

new

and

or

and_not

or_not

expression

For more information see code and test.

Name

QBit::Application::Model::DB::Query

Description

Base class for DB queries.

Abstract methods

Package methods

init

No arguments.

Method called from "new" before return object.

select

Arguments:

Return values:

Example:

my $query = $app->db->query->select(
    table  => $app->db->users,
    fields => [qw(id login)],
    filter => {id => 3},
);

join

Arguments:

Return values:

Example:

 my $join_query = $query->join(
     table     => $app->db->fio,
     fields    => [qw(name surname)],
     filter    => ['name' => 'LIKE' => \'Max'],
     join_type => 'INNER JOIN',
     join_on   => ['user_id' => '=' => {'id' => $app->db->users}],
 );

left_join

join_type => 'LEFT JOIN'

right_join

join_type => 'RIGHT JOIN'

group_by

Arguments:

Return values:

Example:

 my $group_query = $query->group_by(qw(name surname));

order_by

Arguments:

Return values:

Example:

 my $order_query = $query->order_by('id', ['login', 1]);

limit

Arguments:

Return values:

Example:

 my $limit_query = $query->limit(100, 200);

distinct

No arguments.

Return values:

Example:

 my $distinct_query = $query->distinct();

union

Arguments:

Return values:

Example:

 my $union_query = $query->union(
     $app->db->query->select(
         table => $app->db->people,
         fields => [qw(id login name surname)]
     ),
     all => FALSE,
 );

union_all

all => TRUE

calc_rows

Arguments:

Return values:

Example:

 my $calc_rows_query = $query->calc_rows(TRUE);

all_langs

Arguments:

Return values:

Example:

 my $all_langs_query = $query->all_langs(TRUE);

for_update

No arguments.

Return values:

Example:

 my $for_update_query = $query->for_update();

filter

get_sql_with_data

Arguments:

Return values:

Example:

 my $sql = $query->get_sql_with_data();

get_all

No arguments.

Return values:

Example:

my $data = $query->get_all();

found_rows

No arguments.

Return values:

Example:

 my $bool = $query->found_rows();

For more information see code and test.

Name

QBit::Application::Model::DB::Table

Description

Base class for DB tables.

RO accessors

Abstract methods

Package methods

init

No arguments.

Method called from "new" before return object.

fields

No arguments.

Return values:

Example:

 my $fields = $app->db->users->fields();

fields

No arguments.

Return values:

Example:

 my @field_names = $app->db->users->field_names();

get_all

Arguments:

For more information see QBit::Application::Model::DB::Query::get_all

Return values:

Example:

my $data = $app->db->users->get_all(
    fields => [qw(id login)],
    filter => {id => 3},
);

get

Arguments:

For more information see QBit::Application::Model::DB::Query::get_all

Return values:

Example:

my $data = $app->db->users->get(3, fields => [qw(id login)],);

truncate

No arguments.

Truncate table.

Example:

 $app->db->users->truncate();

default_fields

You can redefine this method in your Model.

default_primary_key

You can redefine this method in your Model.

default_indexes

You can redefine this method in your Model.

default_foreign_keys

You can redefine this method in your Model.

have_fields

Arguments:

Return values:

Example:

my $bool = $app->db->users->have_fields([qw(id login)]);

For more information see code and test.

Name

QBit::Application::Model::DB::VirtualTable

Description

Base class for DB virtual tables.

RO accessors

Package methods

init

fields

get_sql_with_data

For more information see code and test.