Line: 9 to 9 | ||||||||
---|---|---|---|---|---|---|---|---|
=head1 SYNOPSIS | ||||||||
Changed: | ||||||||
< < | $s = new CGI::Session( "driver:mysql", $sid); $s = new CGI::Session( "driver:mysql", $sid, { DataSource => 'dbi:mysql:test', | |||||||
> > | $s = CGI::Session->new( 'driver:mysql', $sid); $s = CGI::Session->new( 'driver:mysql', $sid, { DataSource => 'dbi:mysql:test', | |||||||
User => 'sherzodr', Password => 'hello' }); | ||||||||
Changed: | ||||||||
< < | $s = new CGI::Session( "driver:mysql", $sid, { Handle => $dbh } ); | |||||||
> > | $s = CGI::Session->new( 'driver:mysql', $sid, { Handle => $dbh } ); | |||||||
=head1 DESCRIPTION | ||||||||
Line: 27 to 27 | ||||||||
a_session TEXT NOT NULL ); | ||||||||
Added: | ||||||||
> > | To use different column names, change the 'create table' statement, and then simply do this: $s = CGI::Session->new('driver:mysql', undef, { TableName=>'session', IdColName=>'my_id', DataColName=>'my_data', DataSource=>'dbi:mysql:project', }); or $s = CGI::Session->new('driver:mysql', undef, { TableName=>'session', IdColName=>'my_id', DataColName=>'my_data', Handle=>$dbh, }); | |||||||
=head2 DRIVER ARGUMENTS
B | ||||||||
Changed: | ||||||||
< < | $s = new CGI::Session( "driver:mysql", $sid, {DataSource=>'shopping_cart'}); | |||||||
> > | $s = CGI::Session->new( 'driver:mysql', $sid, {DataSource=>'shopping_cart'}); | |||||||
# is the same as: | ||||||||
Changed: | ||||||||
< < | $s = new CGI::Session( "driver:mysql", $sid, {DataSource=>'dbi:mysql:shopping_cart'}); | |||||||
> > | $s = CGI::Session->new( 'driver:mysql', $sid, {DataSource=>'dbi:mysql:shopping_cart'}); | |||||||
=head2 BACKWARDS COMPATIBILITY | ||||||||
Changed: | ||||||||
< < | For backwards compatibility, you can also set the table like this before calling C<new()>. However, it is not recommended because it can cause conflicts in a persistent environment. | |||||||
> > | As of V 4.30, the global variable $CGI::Session::MySQL::TABLE_NAME cannot be used to set the session table's name. This is due to changes in CGI::Session::Driver's new() method, which now allows the table's name to be changed (as well as allowing both the 'id' column name and the 'a_session' column name to be changed). See the documentation for CGI::Session::Driver::DBI for details. In particular, the new syntax for C<new()> applies to all database drivers, whereas the old - and bad - global variable method only applied to MySQL. | |||||||
Changed: | ||||||||
< < | $CGI::Session::MySQL::TABLE_NAME = 'my_sessions'; | |||||||
> > | Alternately, call $session -> table_name('new_name') just after creating the session object if you wish to change the session table's name. | |||||||
=head1 LICENSING |
Line: 1 to 1 | ||||||||
---|---|---|---|---|---|---|---|---|
Added: | ||||||||
> > | Package ==extends CGI::Session::Driver::DBI =head1 NAME CGI::Session::Driver::mysql - CGI::Session driver for MySQL database =head1 SYNOPSIS $s = new CGI::Session( "driver:mysql", $sid); $s = new CGI::Session( "driver:mysql", $sid, { DataSource => 'dbi:mysql:test', User => 'sherzodr', Password => 'hello' }); $s = new CGI::Session( "driver:mysql", $sid, { Handle => $dbh } ); =head1 DESCRIPTION B |