NAME
DBIx::SQLEngine::Driver::Trait::DatabaseFlavors - For minor variations in a database
SYNOPSIS
# Classes can import this behavior if they have further subclasses
use DBIx::SQLEngine::Driver::Trait::DatabaseFlavors ':all';
DESCRIPTION
This package supports configurations of drivers or database servers which differ from the generic implementation provided by their driver.
Variations Within a Driver Class
Beyond the fundamental subclassing based on driver type lies a more subtle range of variations.
How do we compensate for different versions of a database system? For example, newer versions of MySQL support a number of features that the old ones don't: transactions were added in 3.23 (for some table types); union selects were added in 4.0; and stored procedures are being added in 5.0. Similarly DBD::SQLite's functionality is limited by the version of the SQLite C library is in use, and DBD::AnyData's level of functionality depends on which version of SQL::Statement is installed.
Similarly, how do we detect driver/server combinations that need extra help? For example, placeholders will fail for Linux users of DBD::Sybase connecting to MS SQL Servers on Windows, so they need a special subclass which uses the NoPlaceholders trait.
This is handled by the "dbms_flavor" interface. When a flavor is selected, detected, or defaulted, the driver in question is reblessed into an appropriate subclass, such as Driver::MySQL::3_23, Driver::MySQL::5_0, or Driver::Sybase::MSSQL.
About Driver Traits
You do not need to use this package directly; it is used internally by those driver subclasses which need it.
Note: this feature has been added recently, and the interface is subject to change.
Note: Because of the way DBIx::AnyDBD munges the inheritance tree, DBIx::SQLEngine subclasses can not reliably inherit from this package. To work around this, we export all of the methods into their namespace using Exporter and @EXPORT.
INTERNAL CONNECTION METHODS (DBI DBH)
Initialization and Reconnection
- _init()
-
$sqldb->_init ()
Calls select_default_dbms_flavor().
Internal method, called by DBIx::AnyDBD after connection is made and class hierarchy has been juggled.
DRIVER AND DATABASE FLAVORS
Detecting DBMS Flavors
- default_dbms_flavor()
-
$sqldb->default_dbms_flavor() : $flavor_name
Subclass hook. Default returns empty string, to not select any flavor.
- detect_dbms_flavor()
-
$sqldb->detect_dbms_flavor() : $flavor_name
Subclass hook. Default returns empty string, to not select any flavor.
Applying DBMS Flavors
- select_dbms_flavor()
-
$sqldb->select_dbms_flavor( $flavor_name )
Reblesses the driver to a subclass based on the flavor name.
- select_default_dbms_flavor()
-
$sqldb->select_default_dbms_flavor( )
Calls select_dbms_flavor() with the result of default_dbms_flavor().
- select_detect_dbms_flavor()
-
$sqldb->select_detect_dbms_flavor( )
Calls select_dbms_flavor() with the result of detect_dbms_flavor() or default_dbms_flavor().
SEE ALSO
See DBIx::SQLEngine for the overall interface and developer documentation.
See DBIx::SQLEngine::Docs::ReadMe for general information about this distribution, including installation and license information.