NAME

MojoX::Mysql - Mojolicious ♥ Mysql

SYNOPSIS

use MojoX::Mysql;
use Mojo::Util qw(dumper);

my %config = (
    user=>'root',
    password=>undef,
    server=>[
        {dsn=>'database=test;host=localhost;port=3306;mysql_connect_timeout=5;', type=>'master'},
        {dsn=>'database=test;host=localhost;port=3306;mysql_connect_timeout=5;', type=>'slave'},
        {dsn=>'database=test;host=localhost;port=3306;mysql_connect_timeout=5;', id=>1, type=>'master'},
        {dsn=>'database=test;host=localhost;port=3306;mysql_connect_timeout=5;', id=>1, type=>'slave'},
        {dsn=>'database=test;host=localhost;port=3306;mysql_connect_timeout=5;', id=>2, type=>'master'},
        {dsn=>'database=test;host=localhost;port=3306;mysql_connect_timeout=5;', id=>2, type=>'slave'},
    ]
);

my $mysql = MojoX::Mysql->new(%config);

DESCRIPTION

MojoX::Mysql is a tiny wrapper around DBD::mysql that makes Mysql a lot of fun to use with the Mojolicious real-time web framework.

ATTRIBUTES

id

$mysql->id(1); # choice id server

slave

$mysql->slave(1); # query only slave server

async

$mysql->async(1); # query async mode

METHODS

db

$mysql->db;

Return MojoX::Mysql::DB object.

do

my ($insertid,$counter) = $mysql->do('INSERT INTO `names` (`id`,`name`) VALUES(1,?)', 'Lilu Kazerogova');

do (choice server)

my ($insertid,$counter) = $mysql->id(1)->do('INSERT INTO `names` (`id`,`name`) VALUES(1,?)', 'Lilu Kazerogova');

query

my $collection_object = $mysql->query('SELECT * FROM `names` WHERE id = ?', 1);

# or

my ($collection,$counter,$sth,$dbh) = $mysql->query('SELECT * FROM `names` WHERE id = ?', 1);

# or callback

$mysql->query('SELECT `text` FROM `test` WHERE `id` = ? LIMIT 1', $insertid, sub {
    my ($self,$data) = @_;
    say dumper $data;
});

Return Mojo::Collection object.

query (choice server)

my $collection_object = $mysql->id(1)->query('SELECT * FROM `names` WHERE id = ?', 1);

# or

my ($collection,$counter,$sth,$dbh) = $mysql->id(1)->query('SELECT * FROM `names` WHERE id = ?', 1);

query (async)

my ($sth1,$dbh1) = $mysql->id(1)->async(1)->query('SELECT SLEEP(?) as `sleep`', 1); # Automatically new connection
my ($sth2,$dbh2) = $mysql->id(1)->async(1)->query('SELECT SLEEP(?) as `sleep`', 1); # Automatically new connection

my $collection_object1 = $mysql->result->async($sth1,$dbh1); # Automatically executed methods finish, commit, disconnect
my $collection_object2 = $mysql->result->async($sth2,$dbh2); # Automatically executed methods finish, commit, disconnect

# Performed concurrently (1 seconds)

Return Mojo::Collection object.

query (slave server)

my $collection_object = $mysql->id(1)->slave(1)->query('SELECT * FROM `names` WHERE id = ?', 1);

# or

my ($collection,$counter,$sth,$dbh) = $mysql->id(1)->slave(1)->query('SELECT * FROM `names` WHERE id = ?', 1);

commit, rollback, disconnect

$mysql->db->commit;
$mysql->db->rollback;
$mysql->db->disconnect;

quote

$mysql->util->quote("test'test");

quote_in

$mysql->util->quote_in("test'test");

# or

$mysql->util->quote_in(['test','test']);

id

$mysql->util->id;

Return id servers in Mojo::Collection object.

Mojolicious Plugin

SEE ALSO Mojolicious::Plugin::Mysql

Mojolicious migration

SEE ALSO Mojolicious::Command::sql

AUTHOR

Kostya Ten, kostya@cpan.org.

COPYRIGHT AND LICENSE

Copyright (C) 2014, Kostya Ten.

This program is free software, you can redistribute it and/or modify it under the terms of the Apache License version 2.0.