mirror of
https://github.com/dg/dibi.git
synced 2025-10-24 03:06:07 +02:00
* DibiConnection::insertId && affectedRows throws exception on failure * added protected throwException() to drivers * DibiPostgreDriver - can build connection string * DibiSqliteDriver - support for parameters 'format:date' & 'format:datetime' * fixed query errors in DibiSqliteDriver * DibiConnection prevents serialization and multiple transactions
144 lines
2.8 KiB
PHP
144 lines
2.8 KiB
PHP
<h1>dibi::connect() example</h1>
|
|
<?php
|
|
|
|
require_once '../dibi/dibi.php';
|
|
|
|
|
|
// connects to SQlite
|
|
echo '<p>Connecting to Sqlite: ';
|
|
try {
|
|
dibi::connect(array(
|
|
'driver' => 'sqlite',
|
|
'database' => 'sample.sdb',
|
|
));
|
|
echo 'OK';
|
|
|
|
} catch (DibiException $e) {
|
|
echo get_class($e), ': ', $e->getMessage(), "\n";
|
|
}
|
|
echo "</p>\n";
|
|
|
|
|
|
|
|
|
|
// connects to MySQL using DSN
|
|
echo '<p>Connecting to MySQL: ';
|
|
try {
|
|
dibi::connect('driver=mysql&host=localhost&username=root&password=xxx&database=test&charset=utf8');
|
|
echo 'OK';
|
|
|
|
} catch (DibiException $e) {
|
|
echo get_class($e), ': ', $e->getMessage(), "\n";
|
|
}
|
|
echo "</p>\n";
|
|
|
|
|
|
|
|
|
|
// connects to MySQLi using array
|
|
echo '<p>Connecting to MySQL: ';
|
|
try {
|
|
dibi::connect(array(
|
|
'driver' => 'mysqli',
|
|
'host' => 'localhost',
|
|
'username' => 'root',
|
|
'password' => 'xxx',
|
|
'database' => 'dibi',
|
|
'charset' => 'utf8',
|
|
));
|
|
echo 'OK';
|
|
|
|
} catch (DibiException $e) {
|
|
echo get_class($e), ': ', $e->getMessage(), "\n";
|
|
}
|
|
echo "</p>\n";
|
|
|
|
|
|
|
|
|
|
// connects to ODBC
|
|
echo '<p>Connecting to ODBC: ';
|
|
try {
|
|
dibi::connect(array(
|
|
'driver' => 'odbc',
|
|
'username' => 'root',
|
|
'password' => '***',
|
|
'dsn' => 'Driver={Microsoft Access Driver (*.mdb)};Dbq='.dirname(__FILE__).'/sample.mdb',
|
|
));
|
|
echo 'OK';
|
|
|
|
} catch (DibiException $e) {
|
|
echo get_class($e), ': ', $e->getMessage(), "\n";
|
|
}
|
|
echo "</p>\n";
|
|
|
|
|
|
|
|
|
|
// connects to PostgreSql
|
|
echo '<p>Connecting to PostgreSql: ';
|
|
try {
|
|
dibi::connect(array(
|
|
'driver' => 'postgre',
|
|
'string' => 'host=localhost port=5432 dbname=mary',
|
|
'persistent' => TRUE,
|
|
));
|
|
echo 'OK';
|
|
|
|
} catch (DibiException $e) {
|
|
echo get_class($e), ': ', $e->getMessage(), "\n";
|
|
}
|
|
echo "</p>\n";
|
|
|
|
|
|
|
|
|
|
// connects to PDO
|
|
echo '<p>Connecting to Sqlite via PDO: ';
|
|
try {
|
|
dibi::connect(array(
|
|
'driver' => 'pdo',
|
|
'dsn' => 'sqlite2::memory:',
|
|
));
|
|
echo 'OK';
|
|
|
|
} catch (DibiException $e) {
|
|
echo get_class($e), ': ', $e->getMessage(), "\n";
|
|
}
|
|
echo "</p>\n";
|
|
|
|
|
|
|
|
// connects to MS SQL
|
|
echo '<p>Connecting to MS SQL: ';
|
|
try {
|
|
dibi::connect(array(
|
|
'driver' => 'mssql',
|
|
'host' => 'localhost',
|
|
'username' => 'root',
|
|
'password' => 'xxx',
|
|
));
|
|
echo 'OK';
|
|
|
|
} catch (DibiException $e) {
|
|
echo get_class($e), ': ', $e->getMessage(), "\n";
|
|
}
|
|
echo "</p>\n";
|
|
|
|
|
|
|
|
// connects to Oracle
|
|
echo '<p>Connecting to Oracle: ';
|
|
try {
|
|
dibi::connect(array(
|
|
'driver' => 'oracle',
|
|
'username' => 'root',
|
|
'password' => 'xxx',
|
|
'database' => 'db',
|
|
));
|
|
echo 'OK';
|
|
|
|
} catch (DibiException $e) {
|
|
echo get_class($e), ': ', $e->getMessage(), "\n";
|
|
}
|
|
echo "</p>\n"; |