1 # <a name="Package <code>="></a> Package =
3 **extends** `CGI::Session::Driver::DBI `
7 <li><a href="#Package =="> Package ==</a></li>
13 CGI::Session::Driver::mysql - CGI::Session driver for [[MySQL]] database
17 $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 \} );
21 B stores session records in a [[MySQL]] table. For details see L<CGI::Session::Driver::DBI|CGI::Session::Driver::DBI>, its parent class.
23 It's especially important for the [[MySQL]] driver that the session ID column be defined as a primary key, or at least "unique", like this:
25 CREATE TABLE sessions ( id CHAR(32) NOT NULL PRIMARY KEY, a\_session TEXT NOT NULL );
27 =head2 DRIVER ARGUMENTS
29 B driver supports all the arguments documented in L<CGI::Session::Driver::DBI|CGI::Session::Driver::DBI>. In addition, I argument can optionally leave leading "dbi:mysql:" string out:
31 $s = new CGI::Session( "driver:mysql", $sid, \{DataSource=>'shopping\_cart'\}); # is the same as: $s = new CGI::Session( "driver:mysql", $sid, \{DataSource=>'dbi:mysql:shopping\_cart'\});
33 =head2 BACKWARDS COMPATIBILITY
35 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.
37 $CGI::Session::MySQL::TABLE\_NAME = 'my\_sessions';
41 For support and licensing see L<CGI::Session|CGI::Session>.