HDBC-mysql-0.2: MySQL driver for HDBCSource codeContentsIndex
Database.HDBC.MySQL
Description

This module provides a MySQL driver for the HDBC database interface. To use it, invoke the connectMySQL method to create an Database.HDBC.IConnection that you can use to interact with a MySQL database. Use the defaultMySQLConnectInfo, overriding the default values as necessary.

 import Control.Monad
 import Database.HDBC
 import Database.HDBC.MySQL
 main = do conn <- connectMySQL defaultMySQLConnectInfo {
                        mysqlHost     = "db1.example.com",
                        mysqlUser     = "scott",
                        mysqlPassword = "tiger"
                     }

           rows <- quickQuery' conn "SELECT 1 + 1" []
           forM_ rows $ \row -> putStrLn $ show row

There are some important caveats to note about this driver.

The first relates to transaction support. The MySQL server supports a variety of backend "engines", only some of which support transactional access (e.g., InnoDB). This driver will report that the database supports transactions. Should you decide to make use of the transactional support in the HDBC API, it is up to you to make sure that you use a MySQL engine that supports transactions.

The next relates to dates and times. MySQL does not store time zone information in DATETIME or TIMESTAMP columns: instead, it assumes that all dates are stored in the "server's time zone". At some point in the future, this driver may query for the server's time zone and apply appropriate time zone conversion to these datatypes. For now, it simply treats all times as UTC; i.e., it assumes the server's time zone is UTC.

Synopsis
connectMySQL :: MySQLConnectInfo -> IO Connection
data MySQLConnectInfo = MySQLConnectInfo {
mysqlHost :: String
mysqlUser :: String
mysqlPassword :: String
mysqlDatabase :: String
mysqlPort :: Int
mysqlUnixSocket :: String
}
defaultMySQLConnectInfo :: MySQLConnectInfo
Documentation
connectMySQL :: MySQLConnectInfo -> IO ConnectionSource
Connects to a MySQL database using the specified connection information.
data MySQLConnectInfo Source

Connection information to use with connectMySQL.

You must either supply a host and port, or the name of a Unix socket.

Constructors
MySQLConnectInfo
mysqlHost :: Stringe.g., "db1.example.com"
mysqlUser :: Stringe.g., "scott"
mysqlPassword :: Stringe.g., "tiger"
mysqlDatabase :: Stringthe "default" database name; e.g., "emp"
mysqlPort :: Inte.g., 3306
mysqlUnixSocket :: Stringe.g., "/var/lib/mysql.sock"
defaultMySQLConnectInfo :: MySQLConnectInfoSource

Typical connection information, meant to be overridden partially, for example:

 connectMySQL defaultMySQLConnectInfo { mysqlHost = "db1" }

In particular, the default values are "127.0.0.1" as the host, 3306 as the port, "root" as the user, no password, and "test" as the default database.

Produced by Haddock version 2.4.2